微信小程序阻止頁面返回實(shí)例詳解(包滑動(dòng)、自動(dòng)返回鍵)
前言
這個(gè)場(chǎng)景還是挺有意思的,比如某多多,只要你點(diǎn)左上角的返回 好家伙,滿滿又 花不了 的優(yōu)惠券就來了,讓你擁有一種消費(fèi)最劃算的感覺。
如果你的場(chǎng)景比較簡(jiǎn)單,只是對(duì)左上角的返回進(jìn)行監(jiān)聽,只需要關(guān)閉自帶的導(dǎo)航欄,手寫導(dǎo)航欄或用ui庫的寫好的導(dǎo)航欄就好了。然后給寫好的導(dǎo)航欄的返回按鈕添加一個(gè)返回的事件做自己想要實(shí)現(xiàn)的場(chǎng)景就好了。
一、自定義導(dǎo)航欄
自定義導(dǎo)航欄配置:
{
"path": "pages/login/login",
"style": {
+ "navigationStyle": "custom"
}
}二、 wx.enableAlertBeforeUnload
如果你的場(chǎng)景點(diǎn)擊返回時(shí)只用來提示一下用戶 類似于用一個(gè)showModel(提示框)的展示效果,可以使用wx.enableAlertBeforeUnload,只要一點(diǎn)擊左上角的返回就會(huì)觸發(fā)當(dāng)前事件,如果點(diǎn)擊確定退出當(dāng)前頁,如果點(diǎn)擊取消留在當(dāng)前頁面。
onLoad(e) {
uni.enableAlertBeforeUnload({
message: "返回上頁時(shí)彈出對(duì)話框",
success: function (res) {
console.log("點(diǎn)擊確認(rèn)按鈕了:", res);
},
fail: function (errMsg) {
console.log("點(diǎn)擊取消按鈕了:", errMsg);
},
})
},三、page-container
如果你的場(chǎng)景比較復(fù)雜,手機(jī)都會(huì)有自帶的滑動(dòng)返回,例如ios的滑動(dòng)返回,安卓的滑動(dòng)返回和back返回鍵,就需要用到page-container,他的效果類似于彈窗的形式存在著。
<page-container :show="true" :duration="false" :overlay="false">
存放內(nèi)容
</page-container>當(dāng)點(diǎn)擊返回按鈕時(shí) 會(huì)先執(zhí)行把當(dāng)前的page-container給隱藏掉,再次點(diǎn)擊返回時(shí)才能夠返回上一頁。

在正常邏輯下 如果想要優(yōu)惠券只彈出一次,只需要把page-container 放在外面 于內(nèi)容隔離開,當(dāng)點(diǎn)擊關(guān)閉時(shí)先把page-container給隱藏掉,并不會(huì)觸發(fā)當(dāng)前頁的返回,當(dāng)關(guān)閉page-container時(shí)會(huì)有離開前的事件,只需要在離開前的事件中添加對(duì)應(yīng)的顯示優(yōu)惠券邏輯即可。
<template>
<view >
<scroll-view scroll-y="true" style="height: 100vh;" :scroll-top="top" class="mainBox" @scroll="scroll">
<view class="" v-for="item in 99">
我是內(nèi)容
</view>
</scroll-view>
<page-container :show="true" :duration="false" :overlay="false" @beforeleave="beforeleave"></page-container>
</view>
</template>
methods:{
beforeleave(){
uni.showModal({
title:'彈出優(yōu)惠券邏輯'
})
},
}
如果呢 你這個(gè)項(xiàng)目比較特別特別的惡心,只要你點(diǎn)擊左上角的返回我就不讓你出去,什么時(shí)候點(diǎn)擊我指定的返回你才夠出去,什么都得聽我的! 實(shí)現(xiàn)思路也是一直在原地進(jìn)入當(dāng)前頁面。好處就是我能知道你想要返回了,確定就是會(huì)有一個(gè)進(jìn)入的加載效果。
完整代碼
<template>
<page-container :show="isShow" :duration="false" :overlay="false" @beforeleave="beforeleave" @afterleave="afterleave" >
<scroll-view scroll-y="true" style="height: 100vh;" :scroll-top="top" class="mainBox" @scroll="scroll">
<view class="back" @click="back">
指定返回按鈕
</view>
<view class="" v-for="item in 99">
我是內(nèi)容
</view>
</view>
</scroll-view>
</page-container>
</template>
<script>
export default {
data() {
return {
isShow:true,
top:0,
scrollTop:0,
}
},
onLoad(e) {
this.top = e.top
},
methods: {
back(){
this.isShow = false
console.log('點(diǎn)擊返回了');
uni.navigateBack()
},
beforeleave(){
if(!this.isShow) return uni.navigateBack()
console.log('點(diǎn)擊返回了');
uni.redirectTo({
url:`/pages/mine/test?top=${this.scrollTop}`,
fail(err) {
console.log(err);
}
})
},
// 需要在退出一次 否則退不出去
afterleave(){
if(!this.isShow) return uni.navigateBack()
},
// 記錄當(dāng)前位置 下次進(jìn)來時(shí)自動(dòng)轉(zhuǎn)到剛才的位置
scroll(e){
this.scrollTop = e.target.scrollTop
}
},
}
</script>
總結(jié)
到此這篇關(guān)于微信小程序阻止頁面返回(包滑動(dòng)、自動(dòng)返回鍵)的文章就介紹到這了,更多相關(guān)微信小程序阻止頁面返回內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實(shí)現(xiàn)正則去除a標(biāo)簽并保留內(nèi)容的方法【測(cè)試可用】
這篇文章主要介紹了JavaScript實(shí)現(xiàn)正則去除a標(biāo)簽并保留內(nèi)容的方法,結(jié)合實(shí)例形式詳細(xì)分析了javascript針對(duì)a標(biāo)簽及span標(biāo)簽的正則匹配相關(guān)操作技巧,需要的朋友可以參考下2018-07-07
Js參數(shù)RSA加密傳輸之jsencrypt.js的使用
這篇文章主要介紹了Js參數(shù)RSA加密傳輸之jsencrypt.js的使用,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02
BootStrap與validator 使用筆記(JAVA SpringMVC實(shí)現(xiàn))
這篇文章主要介紹了BootStrap與validator 使用筆記(JAVA SpringMVC實(shí)現(xiàn))的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
javascript 解析后的xml對(duì)象的讀取方法細(xì)解
2009-07-07
JS+CSS實(shí)現(xiàn)電子商務(wù)網(wǎng)站導(dǎo)航模板效果代碼
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)電子商務(wù)網(wǎng)站導(dǎo)航模板效果代碼,涉及JavaScript結(jié)合css動(dòng)態(tài)操作頁面元素屬性的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-09-09
js使用文檔就緒函數(shù)動(dòng)態(tài)改變頁面內(nèi)容示例【innerHTML、innerText】
這篇文章主要介紹了js使用文檔就緒函數(shù)動(dòng)態(tài)改變頁面內(nèi)容,結(jié)合實(shí)例形式分析了JavaScript使用innerHTML、innerText函數(shù)動(dòng)態(tài)操作頁面元素相關(guān)使用技巧,需要的朋友可以參考下2019-11-11
關(guān)于javascript 回調(diào)函數(shù)中變量作用域的討論
關(guān)于回調(diào)函數(shù)中變量作用域的討論精品推薦,大家可以參考下。2009-09-09
初學(xué)js 新節(jié)點(diǎn)的創(chuàng)建 刪除 的步驟
對(duì)于js 我是個(gè)初學(xué)者 甚至還不入門,我比較喜歡js做出的特效。2011-07-07

