日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

vue利用popstate实现处理页面返回的方法

發布時間:2023/12/15 综合教程 28 生活家
生活随笔 收集整理的這篇文章主要介紹了 vue利用popstate实现处理页面返回的方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這篇文章運用簡單易懂的例子給大家介紹vue利用popstate實現處理頁面返回的方法,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

需求背景:項目中需要做一個返回確認,避免用戶誤觸返回鍵而退出當前頁面。

原理:利用history和瀏覽器刷新popstate狀態

實現:

1、在mounted() 階段判斷并添加popstate事件監聽,History.pushState()(參數:一個狀態對象,一個標題(現在被忽略了),以及一個可選的URL地址), 注意:IOS版的微信,是會立即觸發popstate事件,所以需要pageshow做下處理,(當一條會話歷史記錄被執行的時候將會觸發頁面顯示(pageshow)事件。(這包括了后退/前進按鈕操作,同時也會在onload 事件觸發后初始化頁面時觸發))

2、在methods里定義監聽操作函數

3、頁面銷毀時,取消監聽。(注意:一定要取消監聽,否則其他vue路由頁面也會被監聽)

補充知識:vue項目監測瀏覽器返回按鈕

在WebApp或瀏覽器中,會有點擊返回、后退、上一頁等按鈕實現自己的關閉頁面、調整到指定頁面、確認離開頁面或執行一些其它操作的需求??梢允褂?popstate 事件進行監聽返回、后退、上一頁操作。

簡單介紹history中的操作

window.history.back(),后退

window.history.forward(),前進

window.history.go(num),前進或后退指定數量歷史記錄

window.history.pushState(state,title,url),在頁面中穿件一個history實體。直接添加到歷史記錄中。參數: state:儲存一個對象,可以添加相關信息,可以使用history.state讀取其中的內容。title: 歷史記錄的標題,url:創建的歷史記錄rul,進行歷史記錄操作時會跳轉到該鏈接。

window.history.replaceState(),修改當前的history實體。

popstate事件,history實體改變時觸發事件

window.history.state,會獲得history實體中的state對象。

使用方法

取消默認的返回操作

添加一條history實體作為替代原來的history實體

mounted () {
 if(window.history&&window.history.pushState){
 history.pushState(null,null,document.URL)
 window.addEventListener('popstate', this.goBack, false);
 }
},
destroyed(){
 window.removeEventListener('popstate',this.goBack,false);
},
methods:{
 goBack(){
 this.$router.replace({path:'/'});
 //replace替換原路由,作用是避免回退死循環
 }
}

總結

以上是生活随笔為你收集整理的vue利用popstate实现处理页面返回的方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。