前言
分享頁面時,希望點擊瀏覽器回退按鈕,回到項目首頁,增加訪問量。
需要監聽瀏覽器的回退按鈕,并阻止其默認事件。
具體步驟如下:
1、掛載完成后,判斷瀏覽器是否支持popstate
1
2
3
4
5
6
|
mounted(){ if (window.history && window.history.pushState) { history.pushState( null , null , document.URL); window.addEventListener( 'popstate' , this .goBack, false ); } }, |
2、頁面銷毀時,取消監聽。否則其他vue路由頁面也會被監聽
1
2
3
|
destroyed(){ window.removeEventListener( 'popstate' , this .goBack, false ); }, |
3、將監聽操作寫在methods里面,removeEventListener取消監聽內容必須跟開啟監聽保持一致,所以函數拿到methods里面寫
1
2
3
4
5
6
|
methods:{ goBack(){ this .$router.replace({path: '/' }); //replace替換原路由,作用是避免回退死循環 } } |
附:popstate用來做什么的?
popstate的怎么用?
HTML5的新API擴展了window.history,使歷史記錄點更加開放了。可以存儲當前歷史記錄點pushState、替換當前歷史記錄點replaceState、監聽歷史記錄點popstate。
pushState、replaceState兩者用法差不多。
使用方法:
1
2
|
history.pushState(data,title,url); //其中第一個參數data是給state的值;第二個參數title為頁面的標題,但當前所有瀏覽器都忽略這個參數,傳個空字符串就好;第三個參數url是你想要去的鏈接; |
replaceState用法類似,例如:history.replaceState("首頁","",location.href+ "#news");
總結
到此這篇關于vue瀏覽器返回監聽的文章就介紹到這了,更多相關vue瀏覽器返回監聽內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/bocongbo/article/details/81667054