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交互全面详解(小结)
# 的是
# 我是
# 加载
# 太多
# 在这个
# 你可以
# 是这样
# 给他
# 可以用
# 中有
# 感兴趣
# 这也
# 希望能
# 要做
# 第二个
# 或者是
# 这个时候
# 谢谢大家
# 方法来
# 来完成
相关文章:
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
开源网站制作软件,开源网站什么意思?
如何快速搭建安全的FTP站点?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
如何在万网主机上快速搭建网站?
如何快速搭建响应式可视化网站?
个人网站制作流程图片大全,个人网站如何注销?
威客平台建站流程解析:高效搭建教程与设计优化方案
建站之星北京办公室:智能建站系统与小程序生成方案解析
北京建设网站制作公司,北京古代建筑博物馆预约官网?
小程序网站制作需要准备什么资料,如何制作小程序?
大连网站制作公司哪家好一点,大连买房网站哪个好?
高防服务器如何保障网站安全无虞?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
如何撰写建站申请书?关键要点有哪些?
建站之星代理商如何保障技术支持与售后服务?
如何在万网自助建站中设置域名及备案?
如何彻底删除建站之星生成的Banner?
如何通过商城自助建站源码实现零基础高效建站?
网站app免费制作软件,能免费看各大网站视频的手机app?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
宝塔面板创建网站无法访问?如何快速排查修复?
建站之星展会模版如何一键下载生成?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
专业公司网站制作公司,用什么语言做企业网站比较好?
如何通过西部数码建站助手快速创建专业网站?
建站三合一如何选?哪家性价比更高?
临沂网站制作公司有哪些,临沂第四中学官网?
如何快速打造个性化非模板自助建站?
网页设计网站制作软件,microsoft office哪个可以创建网页?
建站之星如何快速生成多端适配网站?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
如何通过云梦建站系统实现SEO快速优化?
如何自定义建站之星模板颜色并下载新样式?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
如何使用Golang安装API文档生成工具_快速生成接口文档
如何快速上传自定义模板至建站之星?
教学论文网站制作软件有哪些,写论文用什么软件
?
如何快速生成凡客建站的专业级图册?
北京网站制作网页,网站升级改版需要多久?
宝塔建站助手安装配置与建站模板使用全流程解析
高端智能建站公司优选:品牌定制与SEO优化一站式服务
php json中文编码为null的解决办法
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
建站主机是什么?如何选择适合的建站主机?
建站主机CVM配置优化、SEO策略与性能提升指南
*请认真填写需求信息,我们会在24小时内与您取得联系。