摘要:首先定義一個方法給調(diào)用在中直接調(diào)用該方法可以在中給方法直接傳參,如果方法有返回值,使用是無法獲取到返回值的,需要返回值給的話,可以定義一個方法提供給調(diào)用,然后調(diào)用之后,觸發(fā)該方法把返回值再傳遞給。
當(dāng)前的Android開發(fā)中,會使用大量的h5(html5+css3+js),甚至出現(xiàn)了混合開發(fā)模式(Hybrid),使用Hybrid開發(fā),h5頁面開發(fā)效率高和移植便利性為主。
但在一些地方使用h5開發(fā)的確會不太容易實(shí)現(xiàn),這個時候就需要調(diào)用Java原生方法來完成,就會遇到JavasSript和Java相互調(diào)用,用Java原生方法實(shí)現(xiàn)那些Javascript代碼不容易實(shí)現(xiàn)的功能,比如,異步線程,調(diào)用數(shù)據(jù)庫等..... 然后再暴露給JavaScript調(diào)用。
在Android 4.2之前使用addjavascriptinterface可以把原生的Java方法,給JavaScript調(diào)用,但是這種方案卻存在安全風(fēng)險,在頁面中執(zhí)行一些不可信的Javascript代碼即有可能控制用戶的手機(jī),詳情見:WebView中接口隱患與手機(jī)掛馬利用
Android 4.2之后提供了@JavascriptInterface對象注解的方式建立Javascript對象和android原生對象的綁定,提供給JavaScript調(diào)用的方法必須帶有@JavascriptInterface。
當(dāng)前4.0及4.0之前的系統(tǒng)市場占有量已經(jīng)很低了,因此可以考慮使用minSdkVersion為17,只支持4.2版本以上的手機(jī),低版本的系統(tǒng)不再支持了。
下面就看下Java和Javascript是如何通信的。
為了方便使用,下面使用的示例,不會使用server,所以就需要在webview中使用本地的html文件,為了方便把html文件都放在assets文件夾中,使用本地加載的方式,這樣就不需要服務(wù)器的支持了。
先定義一個html文件:
this is html
使用file:///android_asset/index.html加載到webview中:
private void initView() { webView = (WebView) findViewById(R.id.webView); webView.loadUrl("file:///android_asset/index.html"); }
下面就可以在index.html中試用Java和JavaScript的調(diào)用了。
Javascript調(diào)用Java方法以Android的Toast的為例,下面看下如何從Javascript代碼中調(diào)用系統(tǒng)的Toast。
先定義一個AndroidToast的Java類,它有一個show的方法用來顯示Toast:
public class AndroidToast { @JavascriptInterface public void show(String str) { Toast.makeText(MainActivity.this, str, Toast.LENGTH_SHORT).show(); } }
再對WebView進(jìn)行設(shè)置,開啟JavaScipt,注冊JavascriptInterface的方法:
private void initView() { webView = (WebView) findViewById(R.id.webView); WebSettings webSettings = webView.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setDefaultTextEncodingName("UTF-8"); webView.addJavascriptInterface(new AndroidToast(), "AndroidToast"); webView.loadUrl("file:///android_asset/index.html"); }
addJavascriptInterface的作用是把AndroidToast類映射為Javascript中的AndroidToast。這樣就可以在JavaScript中調(diào)用Java中的方法了。
在Javascript中調(diào)用Java代碼:
function toastClick(){ window.AndroidToast.show("from js"); }
通過window屬性可以找到映射的對象AndroidToast,直接調(diào)用它的show方法即可。
注意這里傳輸?shù)臄?shù)據(jù)只能是基本數(shù)據(jù)類型和string,可以傳輸string就意味著可以使用json傳輸結(jié)構(gòu)化數(shù)據(jù)。
這里調(diào)用的方法并沒有返回值,如果需要在JavaScript中需要得到返回值怎么辦呢?
如果想從Javascript調(diào)的方法里面獲取到返回值,只需要定義一個帶返回值的@JavascriptInterface方法即可:
public class AndroidMessage { @JavascriptInterface public String getMsg() { return "form java"; } }
添加Javascript的映射:
webView.addJavascriptInterface(new AndroidMessage(), "AndroidMessage");
在JavaScript直接調(diào)用:
function showAlert(){ var str=window.AndroidMessage.getMsg(); console.log(str); }
這樣就完成了有返回值的方法調(diào)用。還有一種場景是,在Java中主動觸發(fā)JavaScript方法,就需要在Java中調(diào)用JavaScript方法了。
Java調(diào)用JavaScript方法Java在調(diào)用JavaScript方法的時候,需要使用WebView.loadUrl()方法,它可以直接在頁面里執(zhí)行JavaScript方法。
首先定義一個JavaScript方法給Java調(diào)用:
function callFromJava(str){ console.log(str); }
在Java中直接調(diào)用該方法:
public void javaCallJS(){ webView.loadUrl("javascript:callFromJava("call from java")"); }
可以在loadUrl中給Javascript方法直接傳參,如果JavaScript方法有返回值,使用WebView.loadUrl()是無法獲取到返回值的,需要JavaScript返回值給Java的話,可以定義一個Java方法提供給JavaScript調(diào)用,然后Java調(diào)用JavaScript之后,JavaScript觸發(fā)該方法把返回值再傳遞給Java。
注意WebView.loadUrl()必須在Ui線程中運(yùn)行,不然會會報錯。
項目地址:https://github.com/jjz/androi...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/65752.html
摘要:首先定義一個方法給調(diào)用在中直接調(diào)用該方法可以在中給方法直接傳參,如果方法有返回值,使用是無法獲取到返回值的,需要返回值給的話,可以定義一個方法提供給調(diào)用,然后調(diào)用之后,觸發(fā)該方法把返回值再傳遞給。 當(dāng)前的Android開發(fā)中,會使用大量的h5(html5+css3+js),甚至出現(xiàn)了混合開發(fā)模式(Hybrid),使用Hybrid開發(fā),h5頁面開發(fā)效率高和移植便利性為主。但在一些地方使用...
摘要:好不容易在月號這天中午點(diǎn)左右接到了來自阿里的面試電話。這里會不斷收集和更新基礎(chǔ)相關(guān)的面試題,目前已收集題。面試重難點(diǎn)的和的打包過程多線程機(jī)制機(jī)制系統(tǒng)啟動過程,啟動過程等等掃清面試障礙最新面試經(jīng)驗分享,此為第一篇,開篇。 2016 年末,騰訊,百度,華為,搜狗和滴滴面試題匯總 2016 年未,騰訊,百度,華為,搜狗和滴滴面試題匯總 各大公司 Java 后端開發(fā)面試題總結(jié) 各大公司 Jav...
閱讀 1309·2021-09-27 13:56
閱讀 2338·2019-08-26 10:35
閱讀 3497·2019-08-23 15:53
閱讀 1848·2019-08-23 14:42
閱讀 1233·2019-08-23 14:33
閱讀 3562·2019-08-23 12:36
閱讀 1947·2019-08-22 18:46
閱讀 996·2019-08-22 14:06