国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Android > 正文

Android WebView上實現(xiàn)JavaScript與Java交互

2020-01-02 06:59:52
字體:
供稿:網(wǎng)友

其實webview加載資源的速度并不慢,但是如果資源多了,當然就很慢。圖片、css 、js 、html這些資源每個大概需要10-200ms ,一般都是30ms就ok了。不過webview是必須等到全部資源都完成加載,才會進行渲染的,所以加載的速度很重要!從Google上我們了解到,webview加載頁面的順序是:先加載html,然后從里面解析出css、js文件和頁面上的圖片資源進行加載。如果webkit的緩存里面有,就不加載。加載完這些資源之后,就進行css的渲染和js的執(zhí)行。Css的渲染一般不需要很長時間,幾十毫秒就ok。關鍵是js的執(zhí)行,如果用了jQuery,則執(zhí)行起來需要5-6秒。而在這段時間,如果不在webview里設置背景,網(wǎng)頁部分是白色的,很難看。這是一個很糟糕的用戶體驗。所以#歐#柏泰#克建議如果用網(wǎng)頁布局程序,最好別用那些龐大的js框架。最好使用原生的js寫業(yè)務腳本,以提升加載速度,改善用戶體驗。

在混合開發(fā)中,有時會用到安卓原生SDK,如調(diào)用相機、查看相冊、錄音等,這就需要web頁面中的JavaScript能調(diào)用到安卓SDK接口。由于Android的WebView是基于webkit內(nèi)核的,集成了js與java互調(diào)的接口函數(shù),可以方便地進行開發(fā)使用。

界面布局xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent" ><WebViewandroid:id="@+id/webView"android:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_above="@+id/linearLayout"/><LinearLayout android:id="@+id/linearLayout"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_alignParentBottom="true"><Buttonandroid:id="@+id/btn"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="Java調(diào)用JavaScript接口"></Button></LinearLayout></RelativeLayout> 

java代碼:

private WebView webView;private Handler handler = new Handler();private Button button;@SuppressLint("SetJavaScriptEnabled")@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);webView = (WebView) findViewById(R.id.webView);//自定義webView設置WebSettings webSettings = webView.getSettings();webSettings.setJavaScriptEnabled(true);webView.addJavascriptInterface(new MyJavaScriptInterface(MainActivity.this), "javaInterface");//如果注釋了,javaScript中的alert彈窗等就會失效,不顯示webView.setWebChromeClient(new WebChromeClient());//webView.setWebChromeClient(new MyWebChromeClient());//測試webView加載是否正常//webView.loadUrl("http://www.baidu.com/");webView.setWebViewClient(new HelloWebView());webView.loadUrl("file:///android_asset/index.html");button = (Button) findViewById(R.id.btn);button.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String param = "bb";webView.loadUrl("javascript:showTitle('"+param+"')");}});}private class HelloWebView extends WebViewClient{@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {// TODO Auto-generated method stubview.loadUrl(url);return true;} }/*** 在主線程中定義JavaScript可以調(diào)用的安卓接口* @author CHQ* API 以后,每個被調(diào)用java函數(shù)都要叫聲明 @JavascriptInterface*/public class MyJavaScriptInterface{private Context context;public MyJavaScriptInterface(Context context){this.context = context;}@JavascriptInterfacepublic String toString() {return "this is interface";}@JavascriptInterfacepublic void clickOnAndroid() {Toast.makeText(context, "js調(diào)用安卓:....", Toast.LENGTH_SHORT).show();}/*** 安卓調(diào)用JS接口,要開啟子線程調(diào)用*/@JavascriptInterfacepublic void call() {Toast.makeText(context, "安卓客戶端再調(diào)用JavaScript接口", Toast.LENGTH_SHORT).show();handler.post(new Runnable() { @Overridepublic void run() {String param = "bb";webView.loadUrl("javascript:showTitle('"+param+"')");}});}}

其中:有幾點必須注意的,網(wǎng)上早期關于WebView的描述中,有幾點變化。1)安卓4.2以上的版本中使用WebView實現(xiàn)Java與Js互調(diào),java接口需要聲明@JavascriptInterface ; 2)WebView要調(diào)用setWebChromeClient(),以適應Js等彈窗等實現(xiàn);3)addJavascriptInterface中綁定的接口中調(diào)用JavaScript接口,需要開啟子線程來調(diào)用(報錯:Caused by: java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. );

HTML代碼:

<html><script type="text/javascript">//安卓定義的接口1function callAndroidInterface() {window.javaInterface.clickOnAndroid();}//function showTitle(param) {alert("傳參:"+param);var x = document.getElementById("title");alert("標題:"+x.innerHTML);}</script><body><h3 id="title">關于安卓與JavaScript的交互</h3><input type="button" value="調(diào)用接口1" onclick="callAndroidInterface()"></input> <input type="button" value="測試接口可用性" onclick="showTitle('aa')"></input> <input type="button" value="調(diào)用接口2" onclick="window.javaInterface.call()"></input></body></html> 

以上html文件,其中javaInterface就是webView中addJavacriptInterface()方法中注入的接口入口名稱,通過該名稱就可以直接調(diào)用Java中的接口。(該html頁面需要保持到項目assets目錄中,由webView.loadUrl("file:///android_asset/index.html")來加載);

效果圖:

其中,對話框彈出:網(wǎng)址為"file://"的網(wǎng)頁顯示:,如果是服務器上的web頁面就會顯示源IP地址等等,顯然不是我們想要的。下一篇,我們可以重寫WebChromeClient來修改對話框、確認框等webView的優(yōu)化。

以上內(nèi)容是針對Android WebView上實現(xiàn)JavaScript與Java交互的全部內(nèi)容,希望對大家有所幫助!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 宁强县| 封开县| 绥芬河市| 东乡| 土默特右旗| 岐山县| 崇州市| 台南县| 河曲县| 抚宁县| 蚌埠市| 寻甸| 建湖县| 甘肃省| 开阳县| 黔东| 盐源县| 建平县| 长治县| 化州市| 荆州市| 镶黄旗| 赣州市| 阳泉市| 桂林市| 内乡县| 怀柔区| 望都县| 宕昌县| 景泰县| 涞水县| 定边县| 寿光市| 酉阳| 巍山| 奉化市| 宜都市| 禹城市| 迭部县| 沐川县| 阳信县|