美文网首页
WebView和JS交互方式

WebView和JS交互方式

作者: badcyc | 来源:发表于2017-10-29 17:22 被阅读0次

    Webview和JS交互方式

    前言

    • 现在很多App里都内置了Web网页(Hybrid App),比如说很多电商平台,淘宝,京东等等
    webview_and_JS.png

    1. 交互方式总结

    Android与JS通过Webview互相调用方法,

    • android去调用JS的代码
    • JS去调用Android的代码

    两者沟通的桥梁是WebView

    对于Android调用JS代码的方法有2种:

    1. 通过WebView的loadUrl()
    2. 通过WebView的evaluateJavascript()

    对于JS调用Android代码方法有3种:

    1. 通过WebView的addJavascriptInterface()进行对象映射
    2. 通过 WebViewClient 的shouldOverrideUrlLoading ()方法回调拦截 url
    3. 通过 WebChromeClient 的onJsAlert()、onJsConfirm()、onJsPrompt()方法回调拦截JS对话框alert()、confirm()、prompt() 消息

    2. 交互方式

    对于Android调用JS代码的方法有2种:

    1. 通过WebView的loadUrl()
    2. 通过WebView的evaluateJavascript()
      方式1:通过WebView的loadUrl()
    • 实例介绍:点击Android按钮,即调用WebView JS(文本名为javascript)中callJS()
    步骤1:将需要调用的JS代码以.html格式放到src/main/assets文件夹里

    1.为了方便展示,本文是采用Andorid调用本地JS代码说明;
    2.实际情况时,Android更多的是调用远程JS代码,即将加载的JS代码路径改成url即可

    需要加载JS代码:javascript.html

    // 文本名:javascript
    <!DOCTYPE html>
    <html>
    
       <head>
          <meta charset="utf-8">
          <title>Carson_Ho</title>
    
    // JS代码
         <script>
    // Android需要调用的方法
       function callJS(){
          alert("Android调用了JS的callJS方法");
       }
    </script>
    
       </head>
    
    </html>
    
    步骤2:在Android里通过WebView设置调用JS代码
     public class MainActivity extends AppCompatActivity {
    
        WebView mWebView;
        Button button;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            mWebView =(WebView) findViewById(R.id.webview);
    
            WebSettings webSettings = mWebView.getSettings();
    
            // 设置与Js交互的权限
            webSettings.setJavaScriptEnabled(true);
            // 设置允许JS弹窗
            webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
    
            // 先载入JS代码
            // 格式规定为:file:///android_asset/文件名.html
            mWebView.loadUrl("file:///android_asset/javascript.html");
    
            button = (Button) findViewById(R.id.button);
    
    
            button.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    // 必须另开线程进行JS方法调用(否则无法调用)
                    mWebView.post(new Runnable() {
                        @Override
                        public void run() {
    
                            // 注意调用的JS方法名要对应上
                            // 调用javascript的callJS()方法
                            mWebView.loadUrl("javascript:callJS()");
                        }
                    });
    
                }
            });
    
            // 由于设置了弹窗检验调用结果,所以需要支持js对话框
            // webview只是载体,内容的渲染需要使用webviewChromClient类去实现
            // 通过设置WebChromeClient对象处理JavaScript的对话框
            //设置响应js 的Alert()函数
            mWebView.setWebChromeClient(new WebChromeClient() {
                @Override
                public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {
                    AlertDialog.Builder b = new AlertDialog.Builder(MainActivity.this);
                    b.setTitle("Alert");
                    b.setMessage(message);
                    b.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            result.confirm();
                        }
                    });
                    b.setCancelable(false);
                    b.create().show();
                    return true;
                }
    
            });
    
    
        }
    }
    

    方式2:通过WebView的evaluateJavascript()

     mWebView.evaluateJavascript("javascript:callJS()", new ValueCallback<String>() {
            @Override
            public void onReceiveValue(String value) {
                //此处为 js 返回的结果
            }
        });
    }
    

    相关文章

      网友评论

          本文标题:WebView和JS交互方式

          本文链接:https://www.haomeiwen.com/subject/sciypxtx.html