uni-app和web-view頁(yè)面相互傳參方法實(shí)例
首先:這里說(shuō)的是uni-app開(kāi)發(fā)的APP項(xiàng)目,嵌入web-view頁(yè)面,并進(jìn)行相互傳參,如果和您想了解的內(nèi)容相符,請(qǐng)繼續(xù)閱讀。
一、說(shuō)到web-view嵌入uni-app開(kāi)發(fā)的APP,傳參方面很多人首先會(huì)想到url傳參。
<!-- app端 -->
<view>
<web-view src="www.xxxxx?name=張三"></web-view>
</view>//web端 alert(this.$route.query.name) //張三
這種方法是app向webview傳參最簡(jiǎn)單的方式,但也存在許多弊端:
1.參數(shù)會(huì)被抓取,如果攜帶敏感信息會(huì)存在安全隱患;
2.url會(huì)有長(zhǎng)度限制,如果攜帶的數(shù)據(jù)過(guò)多會(huì)傳不過(guò)去;
3.沒(méi)有對(duì)應(yīng)的webview向app傳參的回傳方法;
4.(重要)不夠裝逼?。?!
二、下面詳細(xì)說(shuō)一下我在項(xiàng)目中用的方法,使用plus.webview.create(url, id, style, {data:{}})的方法攜帶參數(shù),并使用uni.postMessage()的方法回傳參數(shù)。
當(dāng)app給web傳參時(shí):
app中代碼如下:
let wv = plus.webview.create(
'xxx.xxxx.xxx?t=' + new Date().getTime(),//date保證不走緩存
'batch_view',
{
top: '0',
left: '0',
height: '100%',
width: '100%'
},
{
data: {
token: token,
userInfo: userInfo,
implantType: 'uniapp'
}
}) //不用data鍵值對(duì)的方式傳的話,h5接收后會(huì)是多個(gè)字段,而非一個(gè)對(duì)象
let currentWebview = this.$mp.page.$getAppWebview()
currentWebview.append(wv);//重要,否則會(huì)失效H5中代碼如下:
if (window.plus) {
plusReady();
}//加上此判斷以免再瀏覽器打開(kāi)h5頁(yè)面時(shí)報(bào)plus is not define
function plusReady() {
if (plus.webview.getWebviewById("batch_view")) {
const appData = plus.webview.getWebviewById("batch_view").data;
alert(JSON.stringfy(appData))
}
}當(dāng)web給app傳參時(shí):
H5中代碼如下:
<!-- index.html中body引入uni.webview -->
<body>
<div id="app"></div>
<script type="module" src="/src/main.ts"></script>
<script
type="text/javascript"
src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"
></script>
<!-- 以下為驗(yàn)證是否引入成功(可刪) -->
<script type="text/javascript">
// 待觸發(fā) `UniAppJSBridgeReady` 事件后,即可調(diào)用 uni 的 API。
document.addEventListener("UniAppJSBridgeReady", function () {
uni.postMessage({
data: {
action: "6666", // 這是傳的參數(shù)
},
});
});
</script>
</body>//正常使用直接調(diào)用即可
uni.postMessage({
data: {
action: "noToken", // 這是傳的參數(shù)
},
});app中代碼如下:
//建議寫(xiě)在該webview嵌入頁(yè)面的onLoad生命周期中
plus.globalEvent.addEventListener('plusMessage', function(msg) {
console.log(msg.data.args.data.arg)//web傳來(lái)的參數(shù)
if (msg.data.args.data.arg?.action == 'noToken') {
uni.clearStorageSync()
uni.reLaunch({
url: '/pages/login/index'
})
}
})這里說(shuō)一下,官方官方推薦寫(xiě)法是下面這樣,如果是自己再html中方創(chuàng)建的可以使用這種方式,我們是使用plus.webview.create創(chuàng)建的webview木有@message,故用了以上方法。
<web-view @message="handlePostMessage"></web-view>
總結(jié)
到此這篇關(guān)于uni-app和web-view頁(yè)面相互傳參的文章就介紹到這了,更多相關(guān)uni-app和web-view頁(yè)面相互傳參內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
談?wù)凧avaScript自定義回調(diào)函數(shù)
使用Jquery的時(shí)候發(fā)現(xiàn)它里面的很多方法都提供回調(diào)函數(shù),接下來(lái)通過(guò)本篇文章給大家介紹js自定義回調(diào)函數(shù),需要的朋友參考下2015-10-10
基于prototype擴(kuò)展的JavaScript常用函數(shù)庫(kù)
基于prototype擴(kuò)展的JavaScript常用函數(shù)庫(kù)實(shí)現(xiàn)代碼,學(xué)習(xí)js的朋友可以參考下。2010-11-11
Bootstrap柵格系統(tǒng)使用方法及頁(yè)面調(diào)整變形的解決方法
這篇文章主要介紹了Bootstrap柵格系統(tǒng)使用方法及頁(yè)面調(diào)整變形的解決方法,需要的朋友可以參考下2017-03-03
JavaScript中的this原理及6種常見(jiàn)使用場(chǎng)景詳解
這篇文章主要介紹了JavaScript中的this原理及6種常見(jiàn)使用場(chǎng)景詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
JavaScript實(shí)現(xiàn)按鍵精靈的原理分析
這篇文章主要介紹了JavaScript實(shí)現(xiàn)按鍵精靈的原理分析,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
基于javascript實(shí)現(xiàn)圖片切換效果
這篇文章主要介紹了基于javascript實(shí)現(xiàn)圖片切換效果的相關(guān)資料,需要的朋友可以參考下2016-04-04
Bootstrap在線電子商務(wù)網(wǎng)站實(shí)戰(zhàn)項(xiàng)目5
這篇文章主要為大家分享了Bootstrap在線電子商務(wù)網(wǎng)站實(shí)戰(zhàn)項(xiàng)目,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10

