浅谈android和js的交互问题

举报
再见孙悟空_ 发表于 2022/01/13 23:33:10 2022/01/13
【摘要】 现在很多app里面很多功能都用html5实现,也就是用webview加载html显示一些 图文信息。这么做的好处就是减少开发成本 ,一套html在android  ,ios及web都可以跑。节省了很多开发成本。但是这个也就带来相应的一些问题。最大问题就是交互问题。所以下面给大家说一下android和js怎么实现交互(andro...

现在很多app里面很多功能都用html5实现,也就是用webview加载html显示一些 图文信息。这么做的好处就是减少开发成本 ,一套html在android  ,ios及web都可以跑。节省了很多开发成本。但是这个也就带来相应的一些问题。最大问题就是交互问题。所以下面给大家说一下android和js怎么实现交互(android调用js中的方法,js里面调用android的方法)。

一.js调用android

webview设置


  
  1. //设置编码
  2. mWebView.getSettings().setDefaultTextEncodingName("utf-8");
  3. //支持js
  4. mWebView.getSettings().setJavaScriptEnabled(true);
  5. //设置本地调用对象及其接口
  6. mWebView.addJavascriptInterface(new JavaScriptObject(mContext), "myObj");
  7. //载入js
  8. mWebView.loadUrl("file:///android_asset/test.html");

方法声明:


  
  1. class JavaScriptObject {
  2. Context mContxt;
  3. public JavaScriptObject(Context mContxt) {
  4. this.mContxt = mContxt;
  5. }
  6. @JavascriptInterface
  7. public void getAndroidMethod(String name) {
  8. Toast.makeText(mContxt, name, Toast.LENGTH_LONG).show();
  9. }
  10. }


html中js调用


  
  1. <script>
  2. function funFromjs(){
  3. document.getElementById("mydiv").innerHTML="android调用了js的方法";
  4. }
  5. var aTag = document.getElementsByTagName('a')[0];
  6. aTag.addEventListener('click', function(){
  7. //调用android本地方法
  8. myObj.getAndroidMethod("js调用了android的方法!");
  9. return false;
  10. }, false);
  11. </script>

测试的test.html放到android的assets目录下面。

二.android调用js

android 调用js   客户端代码: 

mWebView.loadUrl("javascript:funFromjs()");
 

funFromjs这个函数 是在html里面的js 声明好的。 大家看上面的代码里面有这个函数。

三.特别注意的地方

总的来说很简单,但是有两点需要特别注意的。 

第一点

mWebView.addJavascriptInterface(new JavaScriptObject(mContext), "myObj");
 
myObj.getAndroidMethod("js调用了android的方法!");
 

js代码里面的 myObj  不用特殊定义一个对象 ,这个对象是在android webview加载html时候注入的对象,可以认为他们俩就是一个对象。

第二点@JavascriptInterface

大家注意在android 声明出来的方法前面 要加上这个javasriptInterface 注解,否则会报Uncaught TypeError: Object [object Object] has no method...  这个错误。

正常需要判断为 targetSdkVersion>=17时,需要加上@JavascriptInterface,所以target=android-17或更高以便引入高版本android.jar。反之,如果仅targetSdkVersion低于17,那么目标版本不用加@JavascriptInterface,当然加上也行。

所以大家直接加上就可以。

这个交互的demo我已经上传  下载地址

如果大家还有其它问题或者不同意见,可以评论,也可以加入我的qq群讨论:Android开发经验交流群 454430053

文章来源: wukong.blog.csdn.net,作者:再见孙悟空_,版权归原作者所有,如需转载,请联系作者。

原文链接:wukong.blog.csdn.net/article/details/52623823

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。