前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >浅谈android和js的交互问题

浅谈android和js的交互问题

作者头像
再见孙悟空_
发布2023-02-16 14:48:21
7910
发布2023-02-16 14:48:21
举报

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

一.js调用android

webview设置

代码语言:javascript
复制
//设置编码
        mWebView.getSettings().setDefaultTextEncodingName("utf-8");
        //支持js
        mWebView.getSettings().setJavaScriptEnabled(true);
        //设置本地调用对象及其接口
        mWebView.addJavascriptInterface(new JavaScriptObject(mContext), "myObj");
        //载入js
        mWebView.loadUrl("file:///android_asset/test.html");

方法声明:

代码语言:javascript
复制
class JavaScriptObject {
        Context mContxt;
        public JavaScriptObject(Context mContxt) {
            this.mContxt = mContxt;
        }
        @JavascriptInterface
        public void getAndroidMethod(String name) {
            Toast.makeText(mContxt, name, Toast.LENGTH_LONG).show();
        }
    }

html中js调用

代码语言:javascript
复制
<script>
    
    function funFromjs(){
    	document.getElementById("mydiv").innerHTML="android调用了js的方法";
    }
    var aTag = document.getElementsByTagName('a')[0];
    aTag.addEventListener('click', function(){
        //调用android本地方法
    myObj.getAndroidMethod("js调用了android的方法!");
        return false;
    }, false);
    </script>

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

二.android调用js

android 调用js   客户端代码: 

代码语言:javascript
复制
mWebView.loadUrl("javascript:funFromjs()");

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

三.特别注意的地方

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

第一点

代码语言:javascript
复制
mWebView.addJavascriptInterface(new JavaScriptObject(mContext), "myObj");
代码语言:javascript
复制
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我已经上传  下载地址

如果大家还有其它问题或者不同意见,可以评论

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-09-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一.js调用android
  • 二.android调用js
  • 三.特别注意的地方
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档