欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中監(jiān)聽(tīng)返回鍵問(wèn)題

 更新時(shí)間:2019年08月28日 14:14:14   作者:wangnima666  
這篇文章主要介紹了解決vue中監(jiān)聽(tīng)返回鍵問(wèn)題,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

問(wèn)題:在項(xiàng)目中,我們常常有需求,當(dāng)用戶(hù)在填寫(xiě)表單時(shí),點(diǎn)擊返回的時(shí)候,我們希望加一個(gè)彈窗,確認(rèn)離開(kāi)嗎,確認(rèn)將保存為草稿

解決方案:利用 H5的 pushstate(個(gè)人理解為增加頁(yè)面棧)特性與onpopup事件

分析:pushstate 從該方法名我們可以知道 是增加某種狀態(tài),會(huì)為history對(duì)象的length增加長(zhǎng)度, 點(diǎn)擊返回鍵的時(shí)候會(huì)觸發(fā)onpopup事件(可以聯(lián)想到 pop其實(shí)是數(shù)組刪除的最后一個(gè)元素,符合  ‘棧' 的思想);

          onpopup觸發(fā)返回上一頁(yè),而 pushstate僅僅是從url上進(jìn)行了改變,不會(huì)校驗(yàn)url的內(nèi)容,頁(yè)面不會(huì)改變,加入當(dāng)前頁(yè)面為 xxx/b.html,此時(shí)pushState(null,null,'a.html'),可以發(fā)現(xiàn) url變了,而頁(yè)面的內(nèi)容并沒(méi)有改變,我們可以通過(guò)這來(lái)造成一種無(wú)法返回的假象

實(shí)施:  

//注意:Dialog是一款彈窗的插件
mounted: function() {
//當(dāng)前頁(yè)面掛載的時(shí)候調(diào)用 返回鍵的監(jiān)聽(tīng)方法
this.listeningBack()
}
 //當(dāng)頁(yè)面銷(xiāo)毀的時(shí)候我們也要將事件監(jiān)聽(tīng)銷(xiāo)毀,以免影響其他內(nèi)容
 destroyed:function(){
  window.onpopstate = null
},
methods:{
//監(jiān)聽(tīng)返回鍵
listeningBack() {
var that = this;//window.onpopstate方法指向window,所以要儲(chǔ)存一下當(dāng)前的vue實(shí)例
let route = '上一頁(yè)';//根據(jù)業(yè)務(wù)邏輯的上一頁(yè)決定
window.onpopstate = function() {
//將當(dāng)前頁(yè)面window.location.href 放入頁(yè)面棧當(dāng)中
history.pushState({}, null, window.location.href);
Dialog.alert({
title: '標(biāo)題',
message: '確認(rèn)返回嗎,你所填寫(xiě)的內(nèi)容將保存為草稿'
}).then(() => {
that.$router.push({
path:route
})
}).catch(
console.log('取消返回,留在當(dāng)前頁(yè)面')
);
}
},

}

總結(jié)

以上所述是小編給大家介紹的vue中監(jiān)聽(tīng)返回鍵問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • vue3無(wú)法使用jsx的問(wèn)題及解決

    vue3無(wú)法使用jsx的問(wèn)題及解決

    這篇文章主要介紹了vue3無(wú)法使用jsx的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue3中使用Supabase?Auth方法詳解

    Vue3中使用Supabase?Auth方法詳解

    這篇文章主要為大家介紹了Vue3中使用Supabase?Auth方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài)

    關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài)

    這篇文章主要介紹了關(guān)于Elementui中toggleRowSelection()方法實(shí)現(xiàn)分頁(yè)切換時(shí)記錄之前選中的狀態(tài),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue中el-dialog打開(kāi)與關(guān)閉的幾種方式

    vue中el-dialog打開(kāi)與關(guān)閉的幾種方式

    本文主要介紹了vue中el-dialog打開(kāi)與關(guān)閉的幾種方式,包括 update:visible, ref和兄弟 bus這三種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • vue中axios實(shí)現(xiàn)數(shù)據(jù)交互與跨域問(wèn)題

    vue中axios實(shí)現(xiàn)數(shù)據(jù)交互與跨域問(wèn)題

    這篇文章主要介紹了vue中axios實(shí)現(xiàn)數(shù)據(jù)交互與跨域問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-05-05
  • Vue使用axios引起的后臺(tái)session不同操作

    Vue使用axios引起的后臺(tái)session不同操作

    這篇文章主要介紹了Vue使用axios引起的后臺(tái)session不同操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • vue使用v-for循環(huán)獲取數(shù)組最后一項(xiàng)

    vue使用v-for循環(huán)獲取數(shù)組最后一項(xiàng)

    這篇文章主要介紹了vue使用v-for循環(huán)獲取數(shù)組最后一項(xiàng)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue.draggable實(shí)現(xiàn)表格拖拽排序效果

    vue.draggable實(shí)現(xiàn)表格拖拽排序效果

    這篇文章主要為大家詳細(xì)介紹了vue.draggable實(shí)現(xiàn)表格拖拽排序效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • vue3+vite配置多頁(yè)面的示例代碼

    vue3+vite配置多頁(yè)面的示例代碼

    通過(guò)配置多頁(yè)面應(yīng)用,從而將給子模塊依賴(lài)分隔開(kāi)各自加載,可以減少初始資源的請(qǐng)求,加快頁(yè)面的訪(fǎng)問(wèn)速度,這篇文章主要介紹了vue3+vite配置多頁(yè)面的詳細(xì)過(guò)程,需要的朋友可以參考下
    2023-06-06
  • daisyUI解決TailwindCSS堆砌class問(wèn)題詳解

    daisyUI解決TailwindCSS堆砌class問(wèn)題詳解

    這篇文章主要為大家介紹了daisyUI解決TailwindCSS堆砌class問(wèn)題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07

最新評(píng)論