zoukankan      html  css  js  c++  java
  • 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
                    }
                );
           }

    其他方式,如 文件;

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

     

    源码点击下载

  • 相关阅读:
    最近用到mysql和mybatis结合常用的知识点坐下整理
    采用rest接口对接而非webservice
    Linux 下Nginx 的安装及负载均衡的简单配置
    用websocket实现后台推送消息
    maven项目添加websocket
    Java通过几种经典的算法来实现数组排序
    关于 Java 数组的 12 个最佳方法
    Ajax详解及其案例分析之如何获得Ajax对象,使用Ajax对象发送GET和POST请求,校验用户名,POST和GET请求时的乱码处理,实现级联的下拉列表
    Python
    【作业报告】作业5 四则运算 测试与封装 5.1
  • 原文地址:https://www.cnblogs.com/zhangqie/p/6724252.html
Copyright © 2011-2022 走看看