继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

WebViewJavascriptBridge(H5与原生交互)

娇娇jojo
关注TA
已关注
手记 21
粉丝 8378
获赞 761

作者:娇娇jojo

时间:2018年2月5日

H5和客户端(IOS、安卓)想要交互怎么办(手动头疼)?

答案是肯定的,必要的时候还是要借助一定的工具啦。

我主要研究的是JavascriptBridge,所以今天要说的就这种方法。

而且基于我自己是做前端的,所以单方面的只说JS部分,客户端可以参考:

https://github.com/wangjiaojiao77/WebViewJavascriptBridge(IOS)和

https://github.com/wangjiaojiao77/JsBridge(安卓)。

分批说,先说IOS吧。

1、IOS

先把下面这段代码(这段代码可是会更新的哦,注意及时更新就ok啦)copy到你的JS中。

function setupWebViewJavascriptBridge(callback) {
    if (window.WebViewJavascriptBridge) { return callback(WebViewJavascriptBridge); }
    if (window.WVJBCallbacks) { return window.WVJBCallbacks.push(callback); }
    window.WVJBCallbacks = [callback];
    var WVJBIframe = document.createElement('iframe');
    WVJBIframe.style.display = 'none';
    WVJBIframe.src = 'https://__bridge_loaded__';
    document.documentElement.appendChild(WVJBIframe);
    setTimeout(function() { document.documentElement.removeChild(WVJBIframe) }, 0)
}

然后直接写交互就ok啦(交互无非也就2种:注册一个方法 和 调用已经注册好的方法)。

setupWebViewJavascriptBridge(function(bridge) {

    //注册一个方法(方法名是“JS Echo”),客户端进行调用(方法名也是“JS Echo”),responseCallback是回调函数
    bridge.registerHandler('JS Echo', function(data, responseCallback) {
        console.log("JS Echo called with:", data)
        responseCallback(data)
    })

    //客户端已经注册好一个名为“ObjC Echo”的方法,H5直接进行调用(方法名也为“ObjC Echo”)就行,调用的时候可以传客户端需要的参数
    bridge.callHandler('ObjC Echo', {'key':'value'}, function responseCallback(responseData) {
        console.log("JS received response:", responseData)
    })
})
2、Android

so,安卓也很easy啦。

先把下面这段代码(这段代码可是会更新的哦,注意及时更新就ok啦)copy到你的JS中。

function connectWebViewJavascriptBridge (callback) { 
     if (window.WebViewJavascriptBridge) {
           callback(WebViewJavascriptBridge)
     } else {
           document.addEventListener(
               'WebViewJavascriptBridgeReady'
                , function() {
                     callback(WebViewJavascriptBridge)
                },
                false
           );
     }
}

然后直接写交互就ok啦(其实和IOS一样)。

connectWebViewJavascriptBridge (function(bridge) {

    //注册一个方法(方法名是“JS Echo”),客户端进行调用(方法名也是“JS Echo”),responseCallback是回调函数
    bridge.registerHandler('JS Echo', function(data, responseCallback) {
        console.log("JS Echo called with:", data)
        responseCallback(data)
    })

    //客户端已经注册好一个名为“ObjC Echo”的方法,H5直接进行调用(方法名也为“ObjC Echo”)就行,调用的时候可以传客户端需要的参数
    bridge.callHandler('ObjC Echo', {'key':'value'}, function responseCallback(responseData) {
        console.log("JS received response:", responseData)
    })
})

基本的就是这么写就完啦,详细的可以参照我上面发的网址~~~

打开App,阅读手记
15人推荐
发表评论
随时随地看视频慕课网APP

热门评论

就是安卓和ios都需要交互的话就是上面的代码都在JS里面放吗

可以,,,,,,,,,,,,

您好,我依循您这里的思路,在学习使用 sjbridge的时候,IOS部分,完全可以正常运行,但是Android部分js代码,不知道出错在了哪里,方便的时候可以看一下问题出在哪里么
http://img1.mukewang.com/5e4a8e6f00019b5512320955.jpg

查看全部评论