WebViewJavascriptBridge(H5与原生交互)

/* eslint-disable */
/**
 * 调用原生的一些方法
 * 有些回调绑定到window上,是因为现在安卓回调里不能调用局部变量
 */

// android有问题,回调函数的作用域是window下才能访问,其他传进去的都是undefined
// 提升回调函数到window下解决此问题
window.androidCallbackBridge = null;

function platform() {
    var u = navigator.userAgent;
    let type = "pc"
    if (u.indexOf("Android") > -1 || u.indexOf("Adr") > -1) {
        type = "android"
    } else if (!!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/)) {
        type = "ios"
    }
    return type;
}

function connectWebViewJavascriptBridge(callback) {
    let type = platform()
    if (type == "android") {
        // Android使用
        if (window.WebViewJavascriptBridge) {
            callback(WebViewJavascriptBridge);
        } else {
            document.addEventListener(
                "WebViewJavascriptBridgeReady",
                function() {
                    callback(WebViewJavascriptBridge);
                },
                false
            );
        }
    }
    if (type == "ios") {
        // iOS使用
        if (window.WebViewJavascriptBridge) {
            return callback(window.WebViewJavascriptBridge);
        }
        if (window.WVJBCallbacks) {
            return window.WVJBCallbacks.push(callback);
        }
        window.WVJBCallbacks = [callback];
        var WVJBIframe = document.createElement("iframe");
        WVJBIframe.style.display = "none";
        WVJBIframe.src = "wvjbscheme://__BRIDGE_LOADED__";
        document.documentElement.appendChild(WVJBIframe);
        setTimeout(function() {
            document.documentElement.removeChild(WVJBIframe);
        }, 0);
    }
}

export function $openNewWebView() {
	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)
	    })
	})

}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值