詳解 WebView 與 JS 交互傳值問題
隨著混合開發(fā)模式比較流行,很多時(shí)候,我們需要在原生的基礎(chǔ)上,使用 WebView 加載網(wǎng)頁,這樣控制更加方便。今天我們來看看,如何將 Java 對(duì)象 和 List 集合傳值給 JS 調(diào)用。
如何將 Java 對(duì)象實(shí)例傳值給 JS
其實(shí)將我們?cè)?Android 原生中將 Java 對(duì)象實(shí)例傳值給 JS 承認(rèn)并且可以使用的對(duì)象,方法非常簡單。我們來舉個(gè)例子。
html 文件
我們?cè)诒镜貙懥艘粋€(gè) html 文件,放在 assets 目錄中。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>測(cè)試</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 了嗎?它就是我們傳值進(jìn)行的 Java 對(duì)象實(shí)例。直接就可以使用,獲取了年齡,名字,和性別屬性。那我們?cè)撊绾温暶髟搶?duì)象,才會(huì)被 JS 所承認(rèn)呢?
Java 對(duì)象
來,看看,我們是如何創(chuàng)建 Person 這個(gè)實(shí)體類的。代碼如下:
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;
}
}
看到我們實(shí)體類 Person 中每個(gè)get方法的上面有一個(gè) @JavascriptInterface 的注解了嗎?它的意思就是告訴 JS ,這個(gè)可以用,所以我們?cè)?Html 文件中,使用 person.get()對(duì)應(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 對(duì)象 p 給 webview 為 person,在 JS 調(diào)用的時(shí)候,對(duì)應(yīng)的就是 person 。
wv.loadUrl(“JavaScript:callJS()”);這句話的意思就是:調(diào)用JS中的方法 callJS()函數(shù)方法。
Java List如何傳給 JS 呢?
其實(shí)按道理來說,是不可以將List集合直接傳值給 JS 使用,但是既然對(duì)象可以傳值,JS 可以調(diào)用 java 對(duì)象,也可以調(diào)用 Android 中的方法,那我們就一拆分的形式傳過去。
Html 文件
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>測(cè)試</title>
<h1 id="name" ></h1>
<h1 id="age"></h1>
<h1 id="sex"></h1>
<h1>List傳值測(cè)試</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中的方法,里面可以按照索引返回集合中的對(duì)象,然后再獲取對(duì)象中的屬性。代碼如下:
/**
* 該方法將在js腳本中,通過window.javatojs.....()進(jìn)行調(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()");
整個(gè)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.....()進(jìn)行調(diào)用
*
* @return
*/
@JavascriptInterface
public Person getPersonObject(int index) {
return list.get(index);
}
@JavascriptInterface
public int getSize() {
return list.size();
}
}
效果圖

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
Android Filterable實(shí)現(xiàn)Recyclerview篩選功能的示例代碼
這篇文章主要介紹了Android Filterable實(shí)現(xiàn)Recyclerview篩選功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
Android zxing如何識(shí)別反轉(zhuǎn)二維碼詳解
這篇文章主要給大家介紹了關(guān)于Android zxing如何識(shí)別反轉(zhuǎn)二維碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09
Android中關(guān)于自定義相機(jī)預(yù)覽界面拉伸問題
這篇文章主要為大家詳細(xì)介紹了Android中關(guān)于自定義相機(jī)預(yù)覽界面拉伸問題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
詳解Android權(quán)限管理之Android 6.0運(yùn)行時(shí)權(quán)限及解決辦法
本篇文章主要介紹Android權(quán)限管理之Android 6.0運(yùn)行時(shí)權(quán)限及解決辦法,具有一定的參考價(jià)值,有興趣的可以了解一下。2016-11-11
外層豎向ScrollView,里層橫向ScrollView滑動(dòng)沖突的解決方法
下面小編就為大家?guī)硪黄鈱迂Q向ScrollView,里層橫向ScrollView滑動(dòng)沖突的解決方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04
Android多線程+單線程+斷點(diǎn)續(xù)傳+進(jìn)度條顯示下載功能
這篇文章主要介紹了Android多線程+單線程+斷點(diǎn)續(xù)傳+進(jìn)度條顯示下載功能,需要的朋友可以參考下2017-06-06
Android 仿高德地圖可拉伸的BottomSheet的示例代碼
這篇文章主要介紹了Android 仿高德地圖可拉伸的BottomSheet的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07
android接收到藍(lán)牙配對(duì)請(qǐng)求時(shí)如何點(diǎn)亮屏幕具體實(shí)現(xiàn)
android 在接收到藍(lán)牙配對(duì)請(qǐng)求時(shí)如何自動(dòng)點(diǎn)亮屏幕配對(duì)過程中很實(shí)用,具體的實(shí)現(xiàn)思路及代碼如下,感興趣的朋友可以參考下哈2013-06-06

