這篇文章主要介紹了vue如何實(shí)現(xiàn)與安卓、IOS交互的方法,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)建站專注于中大型企業(yè)的網(wǎng)站建設(shè)、成都做網(wǎng)站和網(wǎng)站改版、網(wǎng)站營銷服務(wù),追求商業(yè)策劃與數(shù)據(jù)分析、創(chuàng)意藝術(shù)與技術(shù)開發(fā)的融合,累計(jì)客戶近千家,服務(wù)滿意度達(dá)97%。幫助廣大客戶順利對接上互聯(lián)網(wǎng)浪潮,準(zhǔn)確優(yōu)選出符合自己需要的互聯(lián)網(wǎng)運(yùn)用,我們將一直專注高端網(wǎng)站設(shè)計(jì)和互聯(lián)網(wǎng)程序開發(fā),在前進(jìn)的路上,與客戶一起成長!
Vue具體輕量級框架、簡單易學(xué)、雙向數(shù)據(jù)綁定、組件化、數(shù)據(jù)和結(jié)構(gòu)的分離、虛擬DOM、運(yùn)行速度快等優(yōu)勢,Vue中頁面使用的是局部刷新,不用每次跳轉(zhuǎn)頁面都要請求所有數(shù)據(jù)和dom,可以大大提升訪問速度和用戶體驗(yàn)。
方案背景
IOS用的是jsBridge插件實(shí)現(xiàn)調(diào)用、傳參、回調(diào)的
安卓是在window掛載方法和掛載回調(diào)的
IOS實(shí)現(xiàn)方案
調(diào)用原生方法封裝如下
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) }) }
實(shí)際調(diào)用如下
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) }) }) }
安卓實(shí)現(xiàn)方案
調(diào)用原生方法
window.HTTP_TEST.functionName()
定義回調(diào)方法/注冊方法給原生
window['functionName'] = res => {}
特殊說明
安卓在交互中的參數(shù)傳遞只能支持string類型,對象參數(shù)要轉(zhuǎn)成string傳遞
因?yàn)榘沧康幕卣{(diào)方法名是固定的,同一方法同時(shí)請求兩次以上時(shí),有可能只得到一次回調(diào)。如果用隨機(jī)數(shù)處理就會不斷地在window上掛載新的函數(shù),調(diào)用次數(shù)過多可能會出問題,所以目前是避免同時(shí)請求同一方法來解決的。如果有需求避免不了,那還是要用隨機(jī)數(shù)解決。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“vue如何實(shí)現(xiàn)與安卓、IOS交互的方法”這篇文章對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
當(dāng)前標(biāo)題:vue如何實(shí)現(xiàn)與安卓、IOS交互的方法
分享鏈接:http://www.rwnh.cn/article32/jscspc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、品牌網(wǎng)站建設(shè)、微信公眾號、外貿(mào)建站、用戶體驗(yàn)、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)