Android之利用JSBridge库实现Html,JavaScript与Android的所有交互

Posted 切切歆语

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android之利用JSBridge库实现Html,JavaScript与Android的所有交互相关的知识,希望对你有一定的参考价值。

java 和 js互通框架 WebViewjavascriptBridge是移动UIView和html交互通信的桥梁,用作者的话来说就是实现java和js的互相调用的桥梁。

替代了WebView的自带的JavascriptInterface的接口,使得我们的开发更加灵活和安全。

本博客把JSBridge库近所有android与(HTML+JS)的交互的方式全部实现,代码详细,注释清除,希望对各位有所帮助。

效果如下图:

      

开发前的准备:(两种方式选择,选一种即可)

   方式1:直接导入JSBridge的library包即可,  AndroidStudio导library包请看博客:AndroidStudio怎样导入library项目开源库

        library包点击下载

 

    方式2:引入库,在bulid.gradle中添加如下代码

              

repositories {
    maven { url "https://jitpack.io" }
}
dependencies {
    compile \'com.github.lzyzsd:jsbridge:1.0.4\'
}

 

1:默认方式(两种(1:DefaultHandler默认的方式);2:自定类实现)

//展示第一种
bridgeWebView.setDefaultHandler(new DefaultHandler());
//data是JavaScript返回的数据
private void setHandler(){

        bridgeWebView.setDefaultHandler(new BridgeHandler() {
            @Override
            public void handler(String data, CallBackFunction function) {
                Toast.makeText(MainActivity.this,"DefaultHandler默认:"+data,Toast.LENGTH_LONG).show();
            }
        });
   }

 

JS

connectWebViewJavascriptBridge(function(bridge) {
            bridge.init(function(message, responseCallback) {
                console.log(\'JS got a message\', message);
                var data = {
                    \'json\': \'JS返回任意数据!\'
                };
                console.log(\'JS responding with\', data);/*打印信息*/
                 document.getElementById("init").innerHTML = "data = " + message;
                responseCallback(data);
            });

 

2:Html点击事件利用JS function方法调Android端并相互传值。

function testClick() {
            var str1 = document.getElementById("text1").value;
            var str2 = document.getElementById("text2").value;

            window.WebViewJavascriptBridge.callHandler(
                \'submitFromWeb\'
                , {\'Data\': \'json数据传给Android端\'}  //该类型是任意类型
                , function(responseData) {
                    document.getElementById("show").innerHTML = "得到Java传过来的数据 data = " + responseData
                }
            );
        }

 

Android.Java

 //注册submitFromWeb方法
        bridgeWebView.registerHandler("submitFromWeb", new BridgeHandler() {
            @Override
            public void handler(String data, CallBackFunction function) {
                Log.i(TAG,"得到JS传过来的数据 data ="+data);
                show(data);
                function.onCallBack("传递数据给JS");
            }
        });

 

3:Android点击事件调用JS方法并相互传值。

 @Override
    public void onClick(View v) {
        //Java 调JS的functionJs方法并得到返回值
        bridgeWebView.callHandler("functionJs", "Android", new CallBackFunction() {
            @Override
            public void onCallBack(String data) {
                // TODO Auto-generated method stub
               show(data);
            }

        });
    }

 

JS.js

 bridge.registerHandler("functionJs", function(data, responseCallback) {
                document.getElementById("show").innerHTML = ("Android端: = " + data);
                var responseData = "Javascript 数据";
                responseCallback(responseData);//回调返回给Android端
            });

 

send方式(包含又返回值和无返回值两种)

无返回值:

bridgeWebView.send("无返回值");
function testClick() {
            var str1 = document.getElementById("text1").value;
            var str2 = document.getElementById("text2").value;
            //将Android端得到的数据在网页上显示,并其他数据传给Android端,  可用于初始化和点击操作
            var data = {id: 1, content: "我是内容哦"};
            window.WebViewJavascriptBridge.send(
                data
                , function(responseData) {
                    document.getElementById("show").innerHTML = "data = " + responseData
                }
            );
       }

 

其他方式,如 文件;

 

代码稍微有点多,就不一一展示了,直接下载即可

 

源码点击下载

 

以上是关于Android之利用JSBridge库实现Html,JavaScript与Android的所有交互的主要内容,如果未能解决你的问题,请参考以下文章

Android自定义view之利用PathEffect实现动态效果

Android自定义view之利用drawArc方法实现动态效果

android与js的交互之jsbridge使用

Android之利用EventBus进行消息传递

Android之利用EventBus进行数据传递

Android开发之利用SQLite进行数据存储