android中Webview与javascript的交互(互相调用)

来源:互联网 发布:美国知乎quora 中国 编辑:程序博客网 时间:2024/05/01 05:23

最近做Android项目中遇到要在webview中做与js交互相关的东东,涉及到js中调用android本地的方法,于是查了资料整理了一下android和js互相调用的过程。如下demo,demo的主要实现过程如下:通过加载本地的html文件(里面有js脚本),实现android本地方法和js中的交互。

第一步:

mainfest.xml中加入网络权限

[java] view plain copy
print?在CODE上查看代码片派生到我的代码片
  1. <uses-permission android:name=“android.permission.INTERNET” />  
    <uses-permission android:name="android.permission.INTERNET" />
第二步:

加载本地写好的html文件(定义好js中提供给android调用的方法 funFromjs(),和android提供给js调用的对象接口fun1FromAndroid(String name)),放在 assets目录下。

[html] view plain copy
print?在CODE上查看代码片派生到我的代码片
  1. <body>  
  2.     <a>js中调用本地方法</a>  
  3.     <script>  
  4.       
  5.     function funFromjs(){  
  6.         document.getElementById(“helloweb”).innerHTML=“HelloWebView,i’m from js”;  
  7.     }  
  8.     var aTag = document.getElementsByTagName(‘a’)[0];  
  9.     aTag.addEventListener(‘click’, function(){  
  10.         //调用android本地方法  
  11.         myObj.fun1FromAndroid(“调用android本地方法fun1FromAndroid(String name)!!”);  
  12.         return false;  
  13.     }, false);  
  14.     </script>  
  15.     <p></p>  
  16.     <div id=“helloweb”>   
  17.   
  18.     </div>  
  19. </body>  
<body>    <a>js中调用本地方法</a>    <script>    function funFromjs(){        document.getElementById("helloweb").innerHTML="HelloWebView,i'm from js";    }    var aTag = document.getElementsByTagName('a')[0];    aTag.addEventListener('click', function(){        //调用android本地方法        myObj.fun1FromAndroid("调用android本地方法fun1FromAndroid(String name)!!");        return false;    }, false);    </script>    <p></p>    <div id="helloweb">     </div></body>

第三步:

实现android工程与js交互的相关代码

android主题代码:

[java] view plain copy
print?在CODE上查看代码片派生到我的代码片
  1. @SuppressLint({ “JavascriptInterface”“SetJavaScriptEnabled” })  
  2.    @Override  
  3.    protected void onCreate(Bundle savedInstanceState) {  
  4.        super.onCreate(savedInstanceState);  
  5.        setContentView(R.layout.activity_main);  
  6.        //初始化  
  7.        initViews();  
  8.   
  9.        //设置编码  
  10.        mWebView.getSettings().setDefaultTextEncodingName(”utf-8”);  
  11.        //支持js  
  12.        mWebView.getSettings().setJavaScriptEnabled(true);  
  13.        //设置背景颜色 透明  
  14.        mWebView.setBackgroundColor(Color.argb(0000));  
  15.        //设置本地调用对象及其接口  
  16.        mWebView.addJavascriptInterface(new JavaScriptObject(mContext), “myObj”);  
  17.        //载入js  
  18.        mWebView.loadUrl(”file:///android_asset/test.html”);  
  19.          
  20.        //点击调用js中方法  
  21.        mBtn1.setOnClickListener(new View.OnClickListener() {  
  22.   
  23.            @Override  
  24.            public void onClick(View v) {  
  25.                mWebView.loadUrl(”javascript:funFromjs()”);  
  26.                Toast.makeText(mContext, ”调用javascript:funFromjs()”, Toast.LENGTH_LONG).show();  
  27.            }  
  28.        });  
  29.   
  30.    }  
 @SuppressLint({ "JavascriptInterface", "SetJavaScriptEnabled" })    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        //初始化        initViews();        //设置编码        mWebView.getSettings().setDefaultTextEncodingName("utf-8");        //支持js        mWebView.getSettings().setJavaScriptEnabled(true);        //设置背景颜色 透明        mWebView.setBackgroundColor(Color.argb(0, 0, 0, 0));        //设置本地调用对象及其接口        mWebView.addJavascriptInterface(new JavaScriptObject(mContext), "myObj");        //载入js        mWebView.loadUrl("file:///android_asset/test.html");        //点击调用js中方法        mBtn1.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                mWebView.loadUrl("javascript:funFromjs()");                Toast.makeText(mContext, "调用javascript:funFromjs()", Toast.LENGTH_LONG).show();            }        });    }
js调用的android对象方法定义

[java] view plain copy
print?在CODE上查看代码片派生到我的代码片
  1. public class JavaScriptObject {  
  2.     Context mContxt;  
  3.     @JavascriptInterface //sdk17版本以上加上注解  
  4.     public JavaScriptObject(Context mContxt) {  
  5.         this.mContxt = mContxt;  
  6.     }  
  7.   
  8.     public void fun1FromAndroid(String name) {  
  9.         Toast.makeText(mContxt, name, Toast.LENGTH_LONG).show();  
  10.     }  
  11.   
  12.     public void fun2(String name) {  
  13.         Toast.makeText(mContxt, ”调用fun2:” + name, Toast.LENGTH_SHORT).show();  
  14.     }  
  15. }  
public class JavaScriptObject {    Context mContxt;    @JavascriptInterface //sdk17版本以上加上注解    public JavaScriptObject(Context mContxt) {        this.mContxt = mContxt;    }    public void fun1FromAndroid(String name) {        Toast.makeText(mContxt, name, Toast.LENGTH_LONG).show();    }    public void fun2(String name) {        Toast.makeText(mContxt, "调用fun2:" + name, Toast.LENGTH_SHORT).show();    }}

效果图:


。。。。


ps:据网友反应,在Android4.4以上不支持js的一些方法了,上面的思想大概是这样,要实用的大家可以参考这个开源项目:

https://github.com/lzyzsd/JsBridge


点击去下载整个demo工程

0 0