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

在vue項(xiàng)目中利用popstate處理頁(yè)面返回的操作介紹

 更新時(shí)間:2020年08月06日 11:35:31   作者:pwy  
這篇文章主要介紹了在vue項(xiàng)目中利用popstate處理頁(yè)面返回的操作介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

需求背景:項(xiàng)目中需要做一個(gè)返回確認(rèn),避免用戶誤觸返回鍵而退出當(dāng)前頁(yè)面。

原理:利用history和瀏覽器刷新popstate狀態(tài)

實(shí)現(xiàn):

1、在mounted() 階段判斷并添加popstate事件監(jiān)聽(tīng),History.pushState()(參數(shù):一個(gè)狀態(tài)對(duì)象,一個(gè)標(biāo)題(現(xiàn)在被忽略了),以及一個(gè)可選的URL地址), 注意:IOS版的微信,是會(huì)立即觸發(fā)popstate事件,所以需要pageshow做下處理,(當(dāng)一條會(huì)話歷史記錄被執(zhí)行的時(shí)候?qū)?huì)觸發(fā)頁(yè)面顯示(pageshow)事件。(這包括了后退/前進(jìn)按鈕操作,同時(shí)也會(huì)在onload 事件觸發(fā)后初始化頁(yè)面時(shí)觸發(fā)))

2、在methods里定義監(jiān)聽(tīng)操作函數(shù)

3、頁(yè)面銷毀時(shí),取消監(jiān)聽(tīng)。(注意:一定要取消監(jiān)聽(tīng),否則其他vue路由頁(yè)面也會(huì)被監(jiān)聽(tīng))

補(bǔ)充知識(shí):vue項(xiàng)目監(jiān)測(cè)瀏覽器返回按鈕

在WebApp或?yàn)g覽器中,會(huì)有點(diǎn)擊返回、后退、上一頁(yè)等按鈕實(shí)現(xiàn)自己的關(guān)閉頁(yè)面、調(diào)整到指定頁(yè)面、確認(rèn)離開(kāi)頁(yè)面或執(zhí)行一些其它操作的需求??梢允褂?popstate 事件進(jìn)行監(jiān)聽(tīng)返回、后退、上一頁(yè)操作。

簡(jiǎn)單介紹history中的操作

window.history.back(),后退

window.history.forward(),前進(jìn)

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

window.history.pushState(state,title,url),在頁(yè)面中穿件一個(gè)history實(shí)體。直接添加到歷史記錄中。參數(shù): state:儲(chǔ)存一個(gè)對(duì)象,可以添加相關(guān)信息,可以使用history.state讀取其中的內(nèi)容。title: 歷史記錄的標(biāo)題,url:創(chuàng)建的歷史記錄rul,進(jìn)行歷史記錄操作時(shí)會(huì)跳轉(zhuǎn)到該鏈接。

window.history.replaceState(),修改當(dāng)前的history實(shí)體。

popstate事件,history實(shí)體改變時(shí)觸發(fā)事件

window.history.state,會(huì)獲得history實(shí)體中的state對(duì)象。

使用方法

取消默認(rèn)的返回操作

添加一條history實(shí)體作為替代原來(lái)的history實(shí)體

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替換原路由,作用是避免回退死循環(huán)
 }
}

以上這篇在vue項(xiàng)目中利用popstate處理頁(yè)面返回的操作介紹就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue-cli配置全局sass、less變量的方法

    vue-cli配置全局sass、less變量的方法

    這篇文章主要介紹了vue-cli配置全局sass、less變量的方法,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • vue3如何通過(guò)provide和inject實(shí)現(xiàn)多層級(jí)組件通信

    vue3如何通過(guò)provide和inject實(shí)現(xiàn)多層級(jí)組件通信

    這篇文章主要介紹了vue3如何通過(guò)provide和inject實(shí)現(xiàn)多層級(jí)組件通信,本文通過(guò)實(shí)例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-11-11
  • Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn)

    Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn)

    關(guān)于這個(gè)Vue-element-admin中的流程可能對(duì)于新的同學(xué)不是很友好,所以本文將結(jié)合實(shí)例代碼,介紹Vue-Element-Admin集成自己的接口實(shí)現(xiàn)登錄跳轉(zhuǎn),感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue項(xiàng)目中實(shí)現(xiàn)緩存的最佳方案詳解

    vue項(xiàng)目中實(shí)現(xiàn)緩存的最佳方案詳解

    這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中實(shí)現(xiàn)緩存的最佳方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • vue 2.0路由之路由嵌套示例詳解

    vue 2.0路由之路由嵌套示例詳解

    這篇文章主要給大家介紹了vue 2.0路由之路由嵌套的相關(guān)資料,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • vue頁(yè)面中使用getElementsByClassName無(wú)法獲取元素的解決

    vue頁(yè)面中使用getElementsByClassName無(wú)法獲取元素的解決

    這篇文章主要介紹了vue頁(yè)面中使用getElementsByClassName無(wú)法獲取元素的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue項(xiàng)目打包成Docker鏡像包的簡(jiǎn)單步驟

    Vue項(xiàng)目打包成Docker鏡像包的簡(jiǎn)單步驟

    最近做時(shí)速云項(xiàng)目部署,需要將前端項(xiàng)目打成鏡像文件,下面這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目打包成Docker鏡像包的簡(jiǎn)單步驟,需要的朋友可以參考下
    2023-10-10
  • vue基礎(chǔ)之ElementUI表格詳解

    vue基礎(chǔ)之ElementUI表格詳解

    這篇文章主要為大家詳細(xì)介紹了vue的ElementUI表格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • uniapp?webview和H5通信的3種方式代碼示例

    uniapp?webview和H5通信的3種方式代碼示例

    最近在研究uni-app跨端開(kāi)發(fā)APP和H5的通訊和交互,比如H5調(diào)用APP的方法,APP往H5里面?zhèn)鲄?H5往app外面?zhèn)鲄?這篇文章主要給大家介紹了關(guān)于uniapp?webview和H5通信的3種方式,需要的朋友可以參考下
    2024-04-04
  • Vue Components 數(shù)字鍵盤(pán)的實(shí)現(xiàn)

    Vue Components 數(shù)字鍵盤(pán)的實(shí)現(xiàn)

    這篇文章主要介紹了Vue Components 數(shù)字鍵盤(pán)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評(píng)論