vue監(jiān)聽(tīng)瀏覽器的后退和刷新事件,阻止默認(rèn)的事件方式
vue監(jiān)聽(tīng)瀏覽器的后退和刷新事件
瀏覽器的后退事件
瀏覽器的后退按鈕,默認(rèn)是返回上一個(gè)路徑的頁(yè)面,可是如果我們當(dāng)前的頁(yè)面有數(shù)據(jù)沒(méi)有被保存的話(huà),點(diǎn)擊后退按鈕應(yīng)該加一層判斷,也是提示用戶(hù)是否需要去保存頁(yè)面的內(nèi)容。
如果不保存,直接返回。
所以需要阻止瀏覽器的后退按鈕,只有在滿(mǎn)足了條件后才執(zhí)行事件
//1 首先進(jìn)入頁(yè)面的時(shí)候需要監(jiān)聽(tīng)瀏覽器的后退按鈕,之后在操作的時(shí)候執(zhí)行函數(shù),在mounted中掛載去監(jiān)聽(tīng)這個(gè)事件,并在methods里面添加函數(shù),用來(lái)判斷執(zhí)行的條件
mounted() {
if (window.history && window.history.pushState) {
history.pushState(null, null, document.URL)
window.addEventListener('popstate', this.back, false)
}
}
// 2:需要在退出頁(yè)面的時(shí)候銷(xiāo)毀這個(gè)監(jiān)聽(tīng)事件
destroyed() {
window.removeEventListener('popstate', this.goBack, false)
},
// 3: 在methods中添加方法,在這里不是使用`this.$router.go(-1)`,因?yàn)槭褂梅祷厣弦徊降脑?huà),方法會(huì)一直返回到第一個(gè)頁(yè)面,
methods: {
back() {
this.$confirm('檢測(cè)到未保存的內(nèi)容,是否在離開(kāi)頁(yè)面前保存修改?', '確認(rèn)信息', {
distinguishCancelAndClose: true,
confirmButtonText: '保存',
cancelButtonText: '放棄修改'
})
.then(() => {
// this.$router.go(-1)
this.$router.push('/about')
// this.$message({
// type: 'info',
// message: '保存修改'
// });
})
.catch(action => {
this.$message({
type: 'info',
message: action === 'cancel' ?
'放棄保存并離開(kāi)頁(yè)面' :
'停留在當(dāng)前頁(yè)面'
})
});
},
}
示例圖:

瀏覽器的刷新事件
和后退事件一個(gè)原因,因?yàn)槲覀冊(cè)谒⑿马?yè)面的時(shí)候,如果這個(gè)時(shí)候頁(yè)面的內(nèi)容沒(méi)有被保存的話(huà),那之前的數(shù)據(jù)都會(huì)丟失,又需要重新填如數(shù)據(jù),這個(gè)時(shí)候肯定心情是比較煩躁的,所以就需要在刷新的時(shí)候去提示一下,用戶(hù)是否已經(jīng)保存了內(nèi)容,因?yàn)楝F(xiàn)在瀏覽器的刷新控件,無(wú)法自定義里面的內(nèi)容,只有默認(rèn)的彈出層控件。所以只能通過(guò)外面添加一層判斷,判斷是否已經(jīng)保存了數(shù)據(jù),如果沒(méi)有保存刷新的時(shí)候就提示,已經(jīng)保存的話(huà)就不提示
// 1 監(jiān)聽(tīng)瀏覽器的刷新事件,注冊(cè)方法
mounted() {
// 監(jiān)聽(tīng)瀏覽器的刷新事件
window.addEventListener('beforeunload', this.unload)
// window.addEventListener('beforeunload', e => this.unload) // 注冊(cè)一個(gè)匿名函數(shù)
}
// 2 銷(xiāo)毀這個(gè)監(jiān)聽(tīng)事件
destroyed() {
// 銷(xiāo)毀這個(gè)監(jiān)聽(tīng)事件,需要找到這個(gè)函數(shù),如果使用的是匿名函數(shù)的話(huà),無(wú)法查找這個(gè)函數(shù),這個(gè)事件也就沒(méi)有辦法被移除 ,在其他頁(yè)面仍然會(huì)執(zhí)行這個(gè)監(jiān)聽(tīng)事件
window.removeEventListener('beforeunload', this.unload)
},
// 3.methods添加方法
methods: {
unload(e) {
e = e || window.event
if (e) {
// 在這里阻止默認(rèn)的刷新,彈出彈框
e.returnValue = '關(guān)閉提示'
}
return '關(guān)閉'
}
}

vue禁止瀏覽器前進(jìn)和后退
最近在做著的這個(gè)項(xiàng)目發(fā)現(xiàn)了一些bug,當(dāng)用戶(hù)點(diǎn)擊瀏覽器的前進(jìn)和撤退的時(shí)候,上一頁(yè)數(shù)據(jù)保存了下來(lái)并沒(méi)有刷新頁(yè)面,這樣會(huì)出現(xiàn)很多奇奇怪怪的bug,我只希望用戶(hù)通過(guò)按鈕來(lái)跳轉(zhuǎn),然后就需要禁止瀏覽器的前進(jìn)和后退
main.js中,增加popstate監(jiān)聽(tīng)
// 禁止瀏覽器前進(jìn)后退 另一部本在router的index.js中
window.addEventListener('popstate', function() {
history.pushState(null, null, document.URL)
})router的index.js中
// 禁止瀏覽器 前進(jìn)和后退,另一部分在main.js中
const router = new VueRouter({
mode: 'history',
routes,
scrollBehavior: () => {
history.pushState(null, null, document.URL)
}
})我一開(kāi)始是想著監(jiān)聽(tīng)瀏覽器返回上一步的時(shí)候,刷新頁(yè)面,但是思索直接把瀏覽器前進(jìn)和后退直接禁用了就可以了,而且代碼也會(huì)更好處理
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- vue項(xiàng)目使用js監(jiān)聽(tīng)瀏覽器關(guān)閉、刷新及后退事件的方法
- vue監(jiān)聽(tīng)瀏覽器網(wǎng)頁(yè)關(guān)閉和網(wǎng)頁(yè)刷新事件代碼示例
- vue3動(dòng)態(tài)監(jiān)聽(tīng)瀏覽器窗口變化實(shí)例
- vue如何監(jiān)聽(tīng)瀏覽器主動(dòng)刷新
- vue瀏覽器返回監(jiān)聽(tīng)的具體步驟
- vue監(jiān)聽(tīng)瀏覽器原生返回按鈕,進(jìn)行路由轉(zhuǎn)跳操作
- 解決vue單頁(yè)面多個(gè)組件嵌套監(jiān)聽(tīng)瀏覽器窗口變化問(wèn)題
相關(guān)文章
element-ui實(shí)現(xiàn)表格邊框的動(dòng)態(tài)切換并防抖
這篇文章主要介紹了element-ui實(shí)現(xiàn)表格邊框的動(dòng)態(tài)切換并防抖方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
Vue通過(guò)provide inject實(shí)現(xiàn)組件通信
這篇文章主要介紹了Vue通過(guò)provide inject實(shí)現(xiàn)組件通信,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
Nuxt項(xiàng)目支持eslint+pritter+typescript的實(shí)現(xiàn)
這篇文章主要介紹了Nuxt項(xiàng)目支持eslint+pritter+typescript的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05
淺談基于Vue.js的移動(dòng)組件庫(kù)cube-ui
這篇文章主要介紹了基于Vue.js的移動(dòng)組件庫(kù)cube-ui,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
vue監(jiān)聽(tīng)瀏覽器網(wǎng)頁(yè)關(guān)閉和網(wǎng)頁(yè)刷新事件代碼示例
在前端開(kāi)發(fā)中我們通常會(huì)遇到這樣的需求,用戶(hù)離開(kāi)、刷新頁(yè)面前,修改數(shù)據(jù)未進(jìn)行保存操作,需要提示框提醒用戶(hù),這篇文章主要給大家介紹了關(guān)于vue監(jiān)聽(tīng)瀏覽器網(wǎng)頁(yè)關(guān)閉和網(wǎng)頁(yè)刷新事件的相關(guān)資料,需要的朋友可以參考下2023-08-08
Ant Design Vue table中列超長(zhǎng)顯示...并加提示語(yǔ)的實(shí)例
這篇文章主要介紹了Ant Design Vue table中列超長(zhǎng)顯示...并加提示語(yǔ)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
vue-cli+webpack在生成的項(xiàng)目中使用bootstrap實(shí)例代碼
本篇文章主要介紹了vue-cli+webpack在生成的項(xiàng)目中使用bootstrap實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-05-05

