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

发布时间 - 2026-01-11 00:23:24    点击率:

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交互全面详解(小结)  # 的是  # 我是  # 加载  # 太多  # 在这个  # 你可以  # 是这样  # 给他  # 可以用  # 中有  # 感兴趣  # 这也  # 希望能  # 要做  # 第二个  # 或者是  # 这个时候  # 谢谢大家  # 方法来  # 来完成 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何快速上传自定义模板至建站之星?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  Laravel如何使用Eloquent进行子查询  如何用花生壳三步快速搭建专属网站?  Internet Explorer官网直接进入 IE浏览器在线体验版网址  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  企业网站制作这些问题要关注  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  iOS正则表达式验证手机号、邮箱、身份证号等  Laravel如何自定义错误页面(404, 500)?(代码示例)  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  如何在IIS7中新建站点?详细步骤解析  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  如何在IIS中配置站点IP、端口及主机头?  在centOS 7安装mysql 5.7的详细教程  Android自定义listview布局实现上拉加载下拉刷新功能  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  如何将凡科建站内容保存为本地文件?  python中快速进行多个字符替换的方法小结  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  如何在Ubuntu系统下快速搭建WordPress个人网站?  Python函数文档自动校验_规范解析【教程】  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  Laravel Docker环境搭建教程_Laravel Sail使用指南  如何确认建站备案号应放置的具体位置?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  如何实现javascript表单验证_正则表达式有哪些实用技巧  Linux系统命令中screen命令详解  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  无锡营销型网站制作公司,无锡网选车牌流程?  jQuery validate插件功能与用法详解  java获取注册ip实例  如何在阿里云完成域名注册与建站?  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  Laravel中的Facade(门面)到底是什么原理  如何快速查询域名建站关键信息?  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  如何快速查询网站的真实建站时间?  如何在宝塔面板中修改默认建站目录?  常州企业网站制作公司,全国继续教育网怎么登录?  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  javascript中对象的定义、使用以及对象和原型链操作小结  千库网官网入口推荐 千库网设计创意平台入口  Mybatis 中的insertOrUpdate操作  Laravel怎么上传文件_Laravel图片上传及存储配置  Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程