vue中監(jiān)聽返回鍵問題
問題:在項目中,我們常常有需求,當(dāng)用戶在填寫表單時,點(diǎn)擊返回的時候,我們希望加一個彈窗,確認(rèn)離開嗎,確認(rèn)將保存為草稿
解決方案:利用 H5的 pushstate(個人理解為增加頁面棧)特性與onpopup事件
分析:pushstate 從該方法名我們可以知道 是增加某種狀態(tài),會為history對象的length增加長度, 點(diǎn)擊返回鍵的時候會觸發(fā)onpopup事件(可以聯(lián)想到 pop其實是數(shù)組刪除的最后一個元素,符合 ‘棧' 的思想);
onpopup觸發(fā)返回上一頁,而 pushstate僅僅是從url上進(jìn)行了改變,不會校驗url的內(nèi)容,頁面不會改變,加入當(dāng)前頁面為 xxx/b.html,此時pushState(null,null,'a.html')
,可以發(fā)現(xiàn) url變了,而頁面的內(nèi)容并沒有改變,我們可以通過這來造成一種無法返回的假象
實施:
//注意:Dialog是一款彈窗的插件 mounted: function() { //當(dāng)前頁面掛載的時候調(diào)用 返回鍵的監(jiān)聽方法 this.listeningBack() } //當(dāng)頁面銷毀的時候我們也要將事件監(jiān)聽銷毀,以免影響其他內(nèi)容 destroyed:function(){ window.onpopstate = null }, methods:{ //監(jiān)聽返回鍵 listeningBack() { var that = this;//window.onpopstate方法指向window,所以要儲存一下當(dāng)前的vue實例 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)聽返回鍵問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
關(guān)于Elementui中toggleRowSelection()方法實現(xiàn)分頁切換時記錄之前選中的狀態(tài)
這篇文章主要介紹了關(guān)于Elementui中toggleRowSelection()方法實現(xiàn)分頁切換時記錄之前選中的狀態(tài),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03vue中axios實現(xiàn)數(shù)據(jù)交互與跨域問題
這篇文章主要介紹了vue中axios實現(xiàn)數(shù)據(jù)交互與跨域問題,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-05-05vue使用v-for循環(huán)獲取數(shù)組最后一項
這篇文章主要介紹了vue使用v-for循環(huán)獲取數(shù)組最后一項問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03daisyUI解決TailwindCSS堆砌class問題詳解
這篇文章主要為大家介紹了daisyUI解決TailwindCSS堆砌class問題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07