方案背景
IOS實現方案
調用原生方法封裝如下
function setupWebViewJavascriptBridge (callback) { if (window.WebViewJavascriptBridge) { return callback(window.WebViewJavascriptBridge) } if (window.WVJBCallbacks) { return window.WVJBCallbacks.push(callback) } window.WVJBCallbacks = [callback] let WVJBIframe = document.createElement('iframe') WVJBIframe.style.display = 'none' WVJBIframe.src = 'https://__bridge_loaded__' document.documentElement.appendChild(WVJBIframe) setTimeout(() => { document.documentElement.removeChild(WVJBIframe) }, 0)}function callhandler (name, data, callback) { setupWebViewJavascriptBridge(function (bridge) { bridge.callHandler(name, data, callback) })}
實際調用如下
callhandler(functionName: string, params: object, res => {})
注冊方法給原生
registerhandler (name, callback) { // 安卓 window[name] = res => { let data = JSON.parse(res) callback(data) } // IOS setupWebViewJavascriptBridge(function (bridge) { bridge.registerHandler(name, function (data, responseCallback) { callback(data, responseCallback) }) })}
安卓實現方案
調用原生方法
window.HTTP_TEST.functionName()
定義回調方法/注冊方法給原生
window['functionName'] = res => {}
特殊說明
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答