Android中webview与JS交互、互调方法实例详解
作者:lqh 发布时间:2023-04-30 19:18:27
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的数据来决定要做什么事,避免大量定义接口 ,也避免构建太多的实例消耗资源
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


猜你喜欢
- spring boot security设置忽略地址不生效最近在试下微服务改造,出现这样一个问题所有请求都经过spring cloud ga
- 一,在一个公共类里创建一个公共方法,然后需要验证的页面都调用这个方法 //在此例子中,就是在入口函数里调用CheckLogin()
- 一、关于Spring Cache缓存在现在的应用中越来越重要,Spring从3.1开始定义了org.springframework.cach
- 本文实例为大家分享了Android联系人字母排序的具体代码,供大家参考,具体内容如下实现思路:首先说下布局,整个是一个相对布局,最下面是一个
- 一、背景当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系
- 引言MyBatis-Plus | 最优雅最简洁地完成数据库操作是对MyBatis-Plus的功能进行简单介绍,虽然是介绍,也让我们领略到他的
- 本文实例为大家分享了Unity3D实现批量下载图片功能的具体代码,供大家参考,具体内容如下下一篇文章试试用线程下载代码如下using Sys
- 1. 初始 Spring Boot1.1 什么是Spring BootSpring 的诞生是为了简化 Java 程序的开发的Spring B
- 本文实例讲述了Java使用Iterator迭代器遍历集合数据的方法。分享给大家供大家参考,具体如下:1、使用迭代器遍历ArrayList集合
- 目前Android在全世界市场上大约有75%的占有率,国人Android手机的持有比例更甚,甚至达到90%以上。因此搞计算机的一听说手机应用
- 目录配置创建OkHttpClient同步get请求异步get请求同步post请求异步post请求上传文件表单提交下面是官网给出的OKHTTP
- 0x01 新建SpringBoot项目1. 新建maven工程ps:在上一教程的基础上操作,就不用新建项目了,请参考文章:SpringBoo
- Java线程池并发执行多个任务Java在语言层面提供了多线程的支持,线程池能够避免频繁的线程创建和销毁的开销,因此很多时候在项目当中我们是使
- 本文实例讲述了Android实现将一个Activity设置成窗口样式的方法。分享给大家供大家参考,具体如下:1.在res/value文件夹下
- springboot加载yml文件获不到值今天使用spring boot读取yml文件,这种多层嵌套的竟然无法读取到(value注解spri
- 一、实验题目二、分析实验要求为:实现一个界面,界面中包含一个文本显示区和两个按钮(存档和读档)读档按钮作用是打开文件并读取内容,将内容显示在
- 在项目开发上,hibernate提供的经验简化了不少工作量和兼容性,但这些绝对需要有经验后才能明白,对于新手来说使用起来很困难。hibern
- Hutool Java工具类库_ExcelUtil依赖<!--Hutool Java工具包--> &l
- 本文实例讲述了Spring使用ClassPathResource加载xml资源。分享给大家供大家参考,具体如下:一 代码package le
- springboot天生支持使用hibernate validation对参数的优雅校验,如果不使用它,只能对参数挨个进行如下方式的手工校验