Android與JS交互的兩種方法

Android與Js交互,知道的有兩種方法

WebView webView=findViewById(R.id.webView);

WebSettings settings =webView.getSetting();
mWebView.loadUrl("網頁url");

一、通過WebClient監聽URL來攔截

1、

webView.setWebViewClient(new WebViewClient() {
@SuppressWarnings("deprecation") @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { if(url.contains("需要監聽的url或者需要監聽的某個字符串")){
	}
                view.loadUrl(url);
               
		return true;
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
            }

            //html頁面加載結束
            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                super.onPageStarted(view, url, favicon);
                Log.e("onPageStarted", url);
            }

	//https環境下需要證書時添加
            @Override
            public void onReceivedSslError(WebView view,
                                           SslErrorHandler handler, SslError error) {
                handler.proceed();// 接受所有網站的證書
            }
        });
如此操作就可以
二、JS調用Android中的方法
	1、添加該行代碼,表示可以與JS交互
		settings.setJavaScriptEnabled(true);
	2、添加該行代碼
		mWebView.addJavascriptInterface(WebActivity.this, "android");
	3、添加如下方法:
		@JavascriptInterface
		public void getToast(String str) {
 			   Toast.makeText(WebActivity.this, str, Toast.LENGTH_LONG).show();
			}
	表示JS代碼中調用android.getToast(“執行了getToast()方法”)方法,當調用的時候會觸發Android代碼中的getToast方法
如果app端和pc端使用的網頁不是同一個的話,兩種方法都可以使用;
如果app端和pc端的網頁是只是在複用,如果監聽的URL是不存在,那麼只能使用第二種方法;
      如果URL是存在的,那麼使用兩種方法都是可以的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章