詳解 WebView 與 JS 交互傳值問題
隨著混合開發(fā)模式比較流行,很多時候,我們需要在原生的基礎(chǔ)上,使用 WebView 加載網(wǎng)頁,這樣控制更加方便。今天我們來看看,如何將 Java 對象 和 List 集合傳值給 JS 調(diào)用。
如何將 Java 對象實例傳值給 JS
其實將我們在 Android 原生中將 Java 對象實例傳值給 JS 承認并且可以使用的對象,方法非常簡單。我們來舉個例子。
html 文件
我們在本地寫了一個 html 文件,放在 assets 目錄中。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>測試</title> <h1 id="name" ></h1> <h1 id="age"></h1> <h1 id="sex"></h1> <script> // Android需要調(diào)用的方法 function callJS(){ document.getElementById("age").innerHTML=person.getAge(); document.getElementById("name").innerHTML=person.getName(); document.getElementById("sex").innerHTML=person.getSex(); } </script> </head> </html>
看到 callJS() 函數(shù)中的 person 了嗎?它就是我們傳值進行的 Java 對象實例。直接就可以使用,獲取了年齡,名字,和性別屬性。那我們該如何聲明該對象,才會被 JS 所承認呢?
Java 對象
來,看看,我們是如何創(chuàng)建 Person 這個實體類的。代碼如下:
package com.loonggg.wedswebview; import android.webkit.JavascriptInterface; /** * Created by loonggg on 2017/5/11. */ public class Person { private String name; private String age; private String sex; @JavascriptInterface public String getAge() { return age; } public void setAge(String age) { this.age = age; } public void setSex(String sex) { this.sex = sex; } @JavascriptInterface public String getSex() { return sex; } @JavascriptInterface public String getName() { return name; } public void setName(String name) { this.name = name; } }
看到我們實體類 Person 中每個get方法的上面有一個 @JavascriptInterface 的注解了嗎?它的意思就是告訴 JS ,這個可以用,所以我們在 Html 文件中,使用 person.get()對應(yīng)的方法,可以獲取到內(nèi)容。
在 WebView 上是這樣傳值的:
webView.loadUrl("file:///android_asset/test_object.html"); final Person p = new Person(); p.setName("loonggg"); p.setAge("28"); p.setSex("男"); wv.addJavascriptInterface(p, "person"); wv.loadUrl("javascript:callJS()");
wv.addJavascriptInterface(p, “person”); 的意思就是注入 Java 對象 p 給 webview 為 person,在 JS 調(diào)用的時候,對應(yīng)的就是 person 。
wv.loadUrl(“JavaScript:callJS()”);這句話的意思就是:調(diào)用JS中的方法 callJS()函數(shù)方法。
Java List如何傳給 JS 呢?
其實按道理來說,是不可以將List集合直接傳值給 JS 使用,但是既然對象可以傳值,JS 可以調(diào)用 java 對象,也可以調(diào)用 Android 中的方法,那我們就一拆分的形式傳過去。
Html 文件
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>測試</title> <h1 id="name" ></h1> <h1 id="age"></h1> <h1 id="sex"></h1> <h1>List傳值測試</h1> <h1 id="name1" ></h1> <h1 id="age1"></h1> <h1 id="sex1"></h1> <script> // Android需要調(diào)用的方法 function callJS(){ document.getElementById("age").innerHTML=person.getAge(); document.getElementById("name").innerHTML=person.getName(); document.getElementById("sex").innerHTML=person.getSex(); } function callListJS(){ document.getElementById("age1").innerHTML=window.javatojs.getPersonObject(0).getAge(); document.getElementById("name1").innerHTML=window.javatojs.getPersonObject(0).getName(); document.getElementById("sex1").innerHTML=window.javatojs.getPersonObject(0).getSex() } </script> </head> </html>
拆分傳值
如何拆分呢?就是在JS中調(diào)用 Android中的方法,里面可以按照索引返回集合中的對象,然后再獲取對象中的屬性。代碼如下:
/** * 該方法將在js腳本中,通過window.javatojs.....()進行調(diào)用 * * @return */ @JavascriptInterface public Person getPersonObject(int index) { return list.get(index); } @JavascriptInterface public int getSize() { return list.size(); } list.add(p); wv.addJavascriptInterface(this, "javatojs"); wv.loadUrl("javascript:callListJS()");
整個Acitvity中所有的代碼
public class MainActivity extends AppCompatActivity { private WebView wv; private List<Person> list = new ArrayList<Person>(); @SuppressLint("JavascriptInterface") @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); wv = new WebView(this); setContentView(wv); WebSettings ws = wv.getSettings(); ws.setJavaScriptEnabled(true); ws.setUseWideViewPort(true);//適應(yīng)分辨率 ws.setLoadWithOverviewMode(true); wv.loadUrl("file:///android_asset/test_object.html"); final Person p = new Person(); p.setName("loonggg"); p.setAge("28"); p.setSex("男"); wv.addJavascriptInterface(p, "person"); list.add(p); wv.addJavascriptInterface(this, "javatojs"); wv.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); wv.loadUrl("javascript:callJS()"); wv.loadUrl("javascript:callListJS()"); } }); } /** * 該方法將在js腳本中,通過window.javatojs.....()進行調(diào)用 * * @return */ @JavascriptInterface public Person getPersonObject(int index) { return list.get(index); } @JavascriptInterface public int getSize() { return list.size(); } }
效果圖
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Android開發(fā)使用UncaughtExceptionHandler捕獲全局異常
本文主要介紹在Android開發(fā)中使用UncaughtExceptionHandler捕獲全局異常,需要的朋友可以參考下。2016-06-06android imageview圖片居中技巧應(yīng)用
做UI布局,尤其是遇到比較復(fù)雜的多重LinearLayout嵌套,常常會被一些比較小的問題困擾上半天,可是無論怎樣設(shè)置layout_gravity屬性,都無法達到效果2012-11-11Android React Native原生模塊與JS模塊通信的方法總結(jié)
這篇文章主要介紹了Android React Native原生模塊與JS模塊通信的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-02-02簡單了解Android性能優(yōu)化方向及相關(guān)工具
這篇文章主要介紹了簡單了解Android性能優(yōu)化方向及相關(guān)工具,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08Android11及以上文件讀寫權(quán)限申請詳細介紹
安卓11改變了此前安卓系統(tǒng)對于文件管理的規(guī)則,在安卓 11 上,文件讀寫變成了特殊權(quán)限,下面這篇文章主要給大家介紹了關(guān)于Android11及以上文件讀寫權(quán)限申請的相關(guān)資料,需要的朋友可以參考下2022-08-08Android使用Retrofit實現(xiàn)自定義Converter解析接口流程詳解
Retrofit是一個RESTful的HTTP網(wǎng)絡(luò)請求框架的封裝,網(wǎng)絡(luò)請求的工作本質(zhì)上是OkHttp完成,而Retrofit僅負責(zé)網(wǎng)絡(luò)請求接口的封裝2023-03-03