vue中監(jiān)聽返回鍵問題
問題:在項(xiàng)目中,我們常常有需求,當(dāng)用戶在填寫表單時(shí),點(diǎn)擊返回的時(shí)候,我們希望加一個(gè)彈窗,確認(rèn)離開嗎,確認(rèn)將保存為草稿
解決方案:利用 H5的 pushstate(個(gè)人理解為增加頁面棧)特性與onpopup事件
分析:pushstate 從該方法名我們可以知道 是增加某種狀態(tài),會(huì)為history對(duì)象的length增加長度, 點(diǎn)擊返回鍵的時(shí)候會(huì)觸發(fā)onpopup事件(可以聯(lián)想到 pop其實(shí)是數(shù)組刪除的最后一個(gè)元素,符合 ‘棧' 的思想);
onpopup觸發(fā)返回上一頁,而 pushstate僅僅是從url上進(jìn)行了改變,不會(huì)校驗(yàn)url的內(nèi)容,頁面不會(huì)改變,加入當(dāng)前頁面為 xxx/b.html,此時(shí)pushState(null,null,'a.html'),可以發(fā)現(xiàn) url變了,而頁面的內(nèi)容并沒有改變,我們可以通過這來造成一種無法返回的假象
實(shí)施:
//注意:Dialog是一款彈窗的插件
mounted: function() {
//當(dāng)前頁面掛載的時(shí)候調(diào)用 返回鍵的監(jiān)聽方法
this.listeningBack()
}
//當(dāng)頁面銷毀的時(shí)候我們也要將事件監(jiān)聽銷毀,以免影響其他內(nèi)容
destroyed:function(){
window.onpopstate = null
},
methods:{
//監(jiān)聽返回鍵
listeningBack() {
var that = this;//window.onpopstate方法指向window,所以要儲(chǔ)存一下當(dāng)前的vue實(shí)例
let route = '上一頁';//根據(jù)業(yè)務(wù)邏輯的上一頁決定
window.onpopstate = function() {
//將當(dāng)前頁面window.location.href 放入頁面棧當(dāng)中
history.pushState({}, null, window.location.href);
Dialog.alert({
title: '標(biāo)題',
message: '確認(rèn)返回嗎,你所填寫的內(nèi)容將保存為草稿'
}).then(() => {
that.$router.push({
path:route
})
}).catch(
console.log('取消返回,留在當(dāng)前頁面')
);
}
},
}
總結(jié)
以上所述是小編給大家介紹的vue中監(jiān)聽返回鍵問題,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
vue proxy 的優(yōu)勢與使用場景實(shí)現(xiàn)
這篇文章主要介紹了vue proxy 的優(yōu)勢與使用場景實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
在Vue使用$attrs實(shí)現(xiàn)構(gòu)建高級(jí)組件
本文我們主要來看下Vue3中的$attrs屬性。首先,我們會(huì)介紹它的用途以及它的實(shí)現(xiàn)與Vue2有哪些不兩同點(diǎn),并通過事例來加深對(duì)它的理解2022-09-09
你不知道的Vue技巧之--開發(fā)一個(gè)可以通過方法調(diào)用的組件(推薦)
這篇文章主要介紹了你不知道的Vue技巧之--開發(fā)一個(gè)可以通過方法調(diào)用的組件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Vue注冊(cè)模塊與登錄狀態(tài)的持久化實(shí)現(xiàn)方法詳解
這篇文章主要介紹了Vue注冊(cè)模塊與登錄狀態(tài)的持久化實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08

