本文介绍: 1.原生调用js (1)loadUrl方法 //js方法参数参数字符串需要单引号 javascript方法名 (参数名) id_webview.loadUrl(“javascript:nativeCallToJS(“+”‘hello xiaocheng‘”+”)”); //原生调JS带参数的方法 function nativeCallToJS(param) { alert(param); }(2)eva
1.原生调用js 
(1)loadUrl方法
        //js方法带参数的 参数为字符串需要单引号 javascript方法名 (参数名)
        id_webview.loadUrl("javascript:nativeCallToJS("+"'hello xiaocheng'"+")");
    //原生调JS带参数的方法
    function nativeCallToJS(param) {
        alert(param);
    }

 (2) evaluateJavascript方法

    //原生调用js 获取返回值 returnResultjs定义的方法 ()不能少
    public void nativeCallToJS2(){
        id_webview.evaluateJavascript("returnResult()", new ValueCallback<String>() {
            @Override
            public void onReceiveValue(String value) {
                Toast.makeText(MainActivity.this,"我是调用js返回数据:"+value,Toast.LENGTH_LONG).show();
            }
        });
    }
    //原生调JS获取返回值
    function returnResult(){
        return 1 + 2;
    }

2.js调用原生

  (1)通过WebView的addJavaScriptInterface()进行对象映射

//1.添加js接口 有这个才能通信 mainActivity统一标识 js与原生标识要一致
id_webview.addJavascriptInterface(MainActivity.this,"mainActivity1");



//2.Js调用原生方法跳页传值
@JavascriptInterface
   public void jsCallNativeToActivity(String msg){
        Intent intent = new Intent(this,SecondActivity.class);
        intent.putExtra("msg",msg);
        startActivity(intent);
   }
    //Js调用原生方法跳页传值
    function jsCallNativeToActivity(param){
        window.mainActivity1.jsCallNativeToActivity(param);
    }

 (2)WebViewClient的ShouldOverrideUrlLoading() 方法进行回调拦截

@Override
  public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
      //通常根据scheme协议格式) & authority(协议名)判断(前两个参数)
      Uri uri = Uri.parse(request.getUrl().toString());
      if (uri.getScheme().equals("org")) {
          if (uri.getAuthority().equals("professor")) {
              LogUtils.i(uri.getQueryParameter("arg1"));
          }
          return true;
      }

      return super.shouldOverrideUrlLoading(view, request);
  }
 function callAndroid(){
  	//协议org://professor?arg1=com&arg2=test
    document.location = "org://professor?arg1=111&arg2=222";
}

 (3) WebChromeClient 的onJsAlert()、onJsConfirm()、onJsPrompt()方法回调分别拦截JS对话框

@Override
  public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) {

      //通常根据scheme协议格式) & authority(协议名)判断(前两个参数)
      Uri uri = Uri.parse(url);
      if (uri.getScheme().equals("org")) {
          if (uri.getAuthority().equals("professor")) {
              LogUtils.i(uri.getQueryParameter("arg1"));
              //参数result:表明消息框的返回值(输入值)
              result.confirm("js调用了Android的方法成功啦");
          }
          return true;
      }

      return super.onJsPrompt(view, url, message, defaultValue, result);
  }
function callAndroid(){
    //document.location = "org://professor?arg1=111&arg2=222";
    var result=prompt("org://professor?arg1=111&arg2=222");
    alert("demo " + result);
}

原文地址:https://blog.csdn.net/day_moon/article/details/123101268

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_24578.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注