全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android中webview与JS交互、互调方法实例详解

Android中webview与JS交互、互调方法实例详解

前言:

对于试水的功能,一般公司都会采用H5的方式来开发,可以用很少的资源与很短的项目工期来完成。
但许多情况下,H5页面会需要一些原生持有的一些如用户信息之类的数据,一些交互也需要调用原生的,如toast之类要保持同一个手机风格一致的交互行为。这个时候就需要能够让JS主动调用原生的方法来进行操作或者获取数据。或者是原生调用JS的方法在H5加载的时候传递一些参数。

对于原生调用JS的方法

我们需要实现一个WebViewClient,在这个WebViewClient里面进行JS方法加载的替换

 webView_.setWebViewClient(new WebViewClient() {
      public void onPageFinished(WebView view, String url) {
        view.loadUrl(MessageFormat.format("javascript:initEvaluationPage({0})",
            Util.wrapGetParameter(json)
        ));
      }
    });

这里的initEvaluationPage必须要和JS的方法名一致

建议传递json格式数据作为参数。

不要忘了允许WebView执行JS代码

webView_.getSettings()s.setJavaScriptEnabled(true);

对于JS调用原生方法,稍微复杂一些

首先,需要本地定义一个接口,接口名需要和JS内写的一致

比如JS需要客户端保存的用户信息

JS中代码是这样的

  var userInfo = JSON.parse(window.JSUserInfoInterface.getUserInfo());

那么我们本地也需要定义一个对应的接口

public interface JSUserInfoInterface {

  @JavascriptInterface
  String getUserInfo();

}

接口名方法名一致

实例化这个接口,在实例方法内返回我们的用户信息

 JSUserInfoInterface method3 = new JSUserInfoInterface() {

      @Override
      @JavascriptInterface
      public String getUserInfo() {
        SharedPreferences sharedPreferences = getActivity().getApplicationContext().getSharedPreferences(
            "share", Context.MODE_PRIVATE);
        String tel = sharedPreferences.getString(Constant.KEY_USERNAME, "");
        String userid = sharedPreferences.getString("userid", "");
        return "{\"user_id\":\"" + userid + "\",\"user_tel\":\"" + tel + "\"}";
      }

    };

注意不能忘了 @JavascriptInterface注解

然后将这个接口方法加入到webView_中,注意第二个参数就是接口名,需要和JS中的一致。

webView_.addJavascriptInterface(method3, "JSUserInfoInterface");

这样就可以在JS调用window.JSUserInfoInterface.getUserInfo()的时候返回我们实例里面给的数据

同样的,我们也可以不返回数据直接执行。比如弹一个原生的Dialog。

需要注意的是JS里面是没有主线程子线程的概念的,当JS进行网络请求的时候,webview会默认给他开子线程。具体机制大家感兴趣可以去了解。不过这也就意味着你不能直接在给JS掉的原生方法中进行UI操作。你可以选择发送给主线程执行。

比如下面的代码我是用rxjava来切换线程的

 JSDialogInterface method2 = new JSDialogInterface() {

      @Override
      @JavascriptInterface
      public void changeDialog(String arg0) {
        Observable.just(arg0)
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(mess -> {
              if (mess.equals("show")) {
                ld_.show();
              } else {
                ld_.dismiss();
              }
            });
      }
    };

最后

一点小建议

如果你的项目中有很多或者一定数量的JS交互,建议写一个有返回值的接口。然后通过JSON参数来进行控制。内部制定一个解析协议,根据JSON的数据来决定要做什么事,避免大量定义接口 ,也避免构建太多的实例消耗资源

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# Android中webview与JS交互、互调方法  # Android  # webview  # JS交互  # Android的WebView与H5前端JS代码交互的实例代码  # Android webview与js的数据交互  # Android总结之WebView与Javascript交互(互相调用)  # Android WebView使用方法详解 附js交互调用方法  # Android中WebView与Js交互的实现方法  # Android WebView上实现JavaScript与Java交互  # android中WebView和javascript实现数据交互实例  # android中webview控件和javascript交互实例  # 解析Android中webview和js之间的交互  # Android WebView与JS交互全面详解(小结)  # 的是  # 我是  # 加载  # 太多  # 在这个  # 你可以  # 是这样  # 给他  # 可以用  # 中有  # 感兴趣  # 这也  # 希望能  # 要做  # 第二个  # 或者是  # 这个时候  # 谢谢大家  # 方法来  # 来完成 


相关文章: 小说建站VPS选用指南:性能对比、配置优化与建站方案解析  英语简历制作免费网站推荐,如何将简历翻译成英文?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  相册网站制作软件,图片上的网址怎么复制?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  制作国外网站的软件,国外有哪些比较优质的网站推荐?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  招贴海报怎么做,什么是海报招贴?  如何在Windows虚拟主机上快速搭建网站?  Android使用GridView实现日历的简单功能  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  黑客如何利用漏洞与弱口令入侵网站服务器?  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  外贸公司网站制作哪家好,maersk船公司官网?  红河网站制作公司,红河事业单位身份证如何上传?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  如何做网站制作流程,*游戏网站怎么搭建?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  如何在宝塔面板中创建新站点?  简历在线制作网站免费版,如何创建个人简历?  如何快速辨别茅台真假?关键步骤解析  在线制作视频的网站有哪些,电脑如何制作视频短片?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  如何安全更换建站之星模板并保留数据?  建站上传速度慢?如何优化加速网站加载效率?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在IIS中配置站点IP、端口及主机头?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  Swift中循环语句中的转移语句 break 和 continue  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  建站之星与建站宝盒如何选择最佳方案?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  如何在Ubuntu系统下快速搭建WordPress个人网站?  大同网页,大同瑞慈医院官网?  如何选择高效便捷的WAP商城建站系统?  建站之星Pro快速搭建教程:模板选择与功能配置指南  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何选择适配移动端的WAP自助建站平台?  建站之星如何取消后台验证码生成?  php json中文编码为null的解决办法  网站图片在线制作软件,怎么在图片上做链接?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  建站之星如何助力企业快速打造五合一网站?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  如何生成腾讯云建站专用兑换码?  太平洋网站制作公司,网络用语太平洋是什么意思? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。