摘要:首先定義一個方法給調用在中直接調用該方法可以在中給方法直接傳參,如果方法有返回值,使用是無法獲取到返回值的,需要返回值給的話,可以定義一個方法提供給調用,然后調用之后,觸發該方法把返回值再傳遞給。
當前的Android開發中,會使用大量的h5(html5+css3+js),甚至出現了混合開發模式(Hybrid),使用Hybrid開發,h5頁面開發效率高和移植便利性為主。
但在一些地方使用h5開發的確會不太容易實現,這個時候就需要調用Java原生方法來完成,就會遇到JavasSript和Java相互調用,用Java原生方法實現那些Javascript代碼不容易實現的功能,比如,異步線程,調用數據庫等..... 然后再暴露給JavaScript調用。
在Android 4.2之前使用addjavascriptinterface可以把原生的Java方法,給JavaScript調用,但是這種方案卻存在安全風險,在頁面中執行一些不可信的Javascript代碼即有可能控制用戶的手機,詳情見:WebView中接口隱患與手機掛馬利用
Android 4.2之后提供了@JavascriptInterface對象注解的方式建立Javascript對象和android原生對象的綁定,提供給JavaScript調用的方法必須帶有@JavascriptInterface。
當前4.0及4.0之前的系統市場占有量已經很低了,因此可以考慮使用minSdkVersion為17,只支持4.2版本以上的手機,低版本的系統不再支持了。
下面就看下Java和Javascript是如何通信的。
為了方便使用,下面使用的示例,不會使用server,所以就需要在webview中使用本地的html文件,為了方便把html文件都放在assets文件夾中,使用本地加載的方式,這樣就不需要服務器的支持了。
先定義一個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的調用了。
Javascript調用Java方法以Android的Toast的為例,下面看下如何從Javascript代碼中調用系統的Toast。
先定義一個AndroidToast的Java類,它有一個show的方法用來顯示Toast:
public class AndroidToast { @JavascriptInterface public void show(String str) { Toast.makeText(MainActivity.this, str, Toast.LENGTH_SHORT).show(); } }
再對WebView進行設置,開啟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中調用Java中的方法了。
在Javascript中調用Java代碼:
function toastClick(){ window.AndroidToast.show("from js"); }
通過window屬性可以找到映射的對象AndroidToast,直接調用它的show方法即可。
注意這里傳輸的數據只能是基本數據類型和string,可以傳輸string就意味著可以使用json傳輸結構化數據。
這里調用的方法并沒有返回值,如果需要在JavaScript中需要得到返回值怎么辦呢?
如果想從Javascript調的方法里面獲取到返回值,只需要定義一個帶返回值的@JavascriptInterface方法即可:
public class AndroidMessage { @JavascriptInterface public String getMsg() { return "form java"; } }
添加Javascript的映射:
webView.addJavascriptInterface(new AndroidMessage(), "AndroidMessage");
在JavaScript直接調用:
function showAlert(){ var str=window.AndroidMessage.getMsg(); console.log(str); }
這樣就完成了有返回值的方法調用。還有一種場景是,在Java中主動觸發JavaScript方法,就需要在Java中調用JavaScript方法了。
Java調用JavaScript方法Java在調用JavaScript方法的時候,需要使用WebView.loadUrl()方法,它可以直接在頁面里執行JavaScript方法。
首先定義一個JavaScript方法給Java調用:
function callFromJava(str){ console.log(str); }
在Java中直接調用該方法:
public void javaCallJS(){ webView.loadUrl("javascript:callFromJava("call from java")"); }
可以在loadUrl中給Javascript方法直接傳參,如果JavaScript方法有返回值,使用WebView.loadUrl()是無法獲取到返回值的,需要JavaScript返回值給Java的話,可以定義一個Java方法提供給JavaScript調用,然后Java調用JavaScript之后,JavaScript觸發該方法把返回值再傳遞給Java。
注意WebView.loadUrl()必須在Ui線程中運行,不然會會報錯。
項目地址:https://github.com/jjz/androi...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/79147.html
摘要:首先定義一個方法給調用在中直接調用該方法可以在中給方法直接傳參,如果方法有返回值,使用是無法獲取到返回值的,需要返回值給的話,可以定義一個方法提供給調用,然后調用之后,觸發該方法把返回值再傳遞給。 當前的Android開發中,會使用大量的h5(html5+css3+js),甚至出現了混合開發模式(Hybrid),使用Hybrid開發,h5頁面開發效率高和移植便利性為主。但在一些地方使用...
摘要:好不容易在月號這天中午點左右接到了來自阿里的面試電話。這里會不斷收集和更新基礎相關的面試題,目前已收集題。面試重難點的和的打包過程多線程機制機制系統啟動過程,啟動過程等等掃清面試障礙最新面試經驗分享,此為第一篇,開篇。 2016 年末,騰訊,百度,華為,搜狗和滴滴面試題匯總 2016 年未,騰訊,百度,華為,搜狗和滴滴面試題匯總 各大公司 Java 后端開發面試題總結 各大公司 Jav...
閱讀 2299·2021-11-24 09:38
閱讀 2121·2021-11-22 14:44
閱讀 1157·2021-07-29 13:48
閱讀 2622·2019-08-29 13:20
閱讀 1120·2019-08-29 11:08
閱讀 2061·2019-08-26 10:58
閱讀 1267·2019-08-26 10:55
閱讀 3163·2019-08-26 10:39