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

js与android和ios原生交互

千岁不倒翁
关注TA
已关注
手记 362
粉丝 60
获赞 387

1、实现原生与js交互

    <!-- 申明交互 这段代码固定必须有 -->function setupWebViewJavascriptBridge(callback) {    //android使用    if (window.WebViewJavascriptBridge) {        callback(window.WebViewJavascriptBridge)    } else {        document.addEventListener(            'WebViewJavascriptBridgeReady'            , function() {                callback(window.WebViewJavascriptBridge)            },            false        );    }    //ios使用    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)}setupWebViewJavascriptBridge(function(bridge) {//oc或android掉js    bridge.registerHandler('result', function(data, responseCallback) {        if(data.errorCode == null  || data.errorCode == "")            window.location.href = "refresh.html?result=success";        else            window.location.href = "refresh.html?result=fail";    });    //js掉原生    $(document).on('click', '#call', function() {        bridge.callHandler('call', {'sessionId':$.cookie("sessionId")}, function(response) {            //处理oc过来的回调            var responseData = { 'Javascript Says':'Right back atcha!' };            responseCallback(responseData);        });    });});
<div>   <a id = "call">跳转手机端 > </a></div>


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