av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

Vue中keep-alive 實(shí)現(xiàn)后退不刷新并保持滾動位置

瀏覽:116日期:2023-01-30 17:43:06

什么是KeepAlive?

首先,我們要明確我們談的是TCP的 KeepAlive 還是HTTP的 Keep-Alive。TCP的KeepAlive和HTTP的Keep-Alive是完全不同的概念,不能混為一談。實(shí)際上HTTP的KeepAlive寫法是Keep-Alive,跟TCP的KeepAlive寫法上也有不同。

TCP的keepalive是側(cè)重在保持客戶端和服務(wù)端的連接,一方會不定期發(fā)送心跳包給另一方,當(dāng)一方端掉的時(shí)候,沒有斷掉的定時(shí)發(fā)送幾次心跳包,如果間隔發(fā)送幾次,對方都返回的是RST,而不是ACK,那么就釋放當(dāng)前鏈接。設(shè)想一下,如果tcp層沒有keepalive的機(jī)制,一旦一方斷開連接卻沒有發(fā)送FIN給另外一方的話,那么另外一方會一直以為這個(gè)連接還是存活的,幾天,幾月。那么這對服務(wù)器資源的影響是很大的。 HTTP的keep-alive一般我們都會帶上中間的橫杠,普通的http連接是客戶端連接上服務(wù)端,然后結(jié)束請求后,由客戶端或者服務(wù)端進(jìn)行http連接的關(guān)閉。下次再發(fā)送請求的時(shí)候,客戶端再發(fā)起一個(gè)連接,傳送數(shù)據(jù),關(guān)閉連接。這么個(gè)流程反復(fù)。但是一旦客戶端發(fā)送connection:keep-alive頭給服務(wù)端,且服務(wù)端也接受這個(gè)keep-alive的話,兩邊對上暗號,這個(gè)連接就可以復(fù)用了,一個(gè)http處理完之后,另外一個(gè)http數(shù)據(jù)直接從這個(gè)連接走了。減少新建和斷開TCP連接的消耗。

二者的作用簡單來說:

HTTP協(xié)議的Keep-Alive意圖在于短時(shí)間內(nèi)連接復(fù)用,希望可以短時(shí)間內(nèi)在同一個(gè)連接上進(jìn)行多次請求/響應(yīng)。

TCP的KeepAlive機(jī)制意圖在于保活、心跳,檢測連接錯(cuò)誤。當(dāng)一個(gè)TCP連接兩端長時(shí)間沒有數(shù)據(jù)傳輸時(shí)(通常默認(rèn)配置是2小時(shí)),發(fā)送keepalive探針,探測鏈接是否存活。

總之,記住HTTP的Keep-Alive和TCP的KeepAlive不是一回事。

tcp的keepalive是在ESTABLISH狀態(tài)的時(shí)候,雙方如何檢測連接的可用行。而http的keep-alive說的是如何避免進(jìn)行重復(fù)的TCP三次握手和四次揮手的環(huán)節(jié)。

正文開始。

vue可以通過<keep-alive>元素包裹組件,實(shí)現(xiàn)緩存,下次使用時(shí)不需要重新創(chuàng)建該組件。但存在一個(gè)問題:keep-alive包裹的組件中有滾動元素時(shí),keep-alive不會儲存滾動位置。

實(shí)現(xiàn)后退不刷新主要依據(jù)keep-alive組件的activated和deactivated這兩個(gè)生命周期鉤子函數(shù)。

vue鉤子函數(shù)的執(zhí)行順序:

不使用keep-alive

beforeRouteEnter --> created --> mounted --> destroyed

使用keep-alive

初次進(jìn)入頁面,beforeRouteEnter --> created --> mounted --> activated --> deactivated

再次進(jìn)入緩存的頁面,只會觸發(fā)beforeRouteEnter -->activated --> deactivated。created和mounted不會再執(zhí)行。

其中,

activated在keep-alive組件激活時(shí)調(diào)用.

deactivated在keep-alive組件被停用時(shí)調(diào)用.

Demo 實(shí)現(xiàn)了后退不刷新,并且返回時(shí)滾動到上次瀏覽的深度。

該demo中,包含三個(gè)鏈接導(dǎo)航。

home --> pageA --> pageB --> pageC

依次前進(jìn),每次前進(jìn)到一個(gè)新頁面都需要獲取數(shù)據(jù),而按下后退鍵后,

從pageC返回到pageB,pageB不再獲取新數(shù)據(jù),而是使用之前緩存的數(shù)據(jù)。

從pageB返回到pageA時(shí),pageA不再獲取新數(shù)據(jù),而是使用之前的數(shù)據(jù)。并且當(dāng)pageA存在滾動條時(shí),返回時(shí)會滾動到上次瀏覽高度。

所以,pageA和pageB需要緩存,pageC不需要緩存。

//router.jsimport Vue from ’vue’;import Router from ’vue-router’;Vue.use(Router);const router = new Router({ mode: ’hash’, routes: [ { path: ’/’, name: ’home’, component: () => import(’./views/Home.vue’), meta: { title: ’首頁’, keepAlive: false //此組件不需要被緩存 } }, { path: ’/pageA’, name: ’pageA’, component: () => import(’./views/pageA.vue’), meta: { title: ’pageA’, keepAlive: true, isBack: false } }, { path: ’/pageB’, name: ’pageB’, component: () => import(’./views/pageB.vue’), meta: { title: ’pageB’, keepAlive: true, isBack: false } }, { path: ’/pageC’, name: ’pageC’, component: () => import(’./views/pageC.vue’), meta: { title: ’pageC’, keepAlive: false } } ]});export default router;//pageA.vue<template> <div class='page-a'> <h1>pageA</h1> <div> <div v-for='item in items' @click='goPageB'> {{ item }} </div> </div> <h1 @click='goPageB'>go pageB</h1> </div></template><script> export default { name: ’PageA’, data() { return { msg: '我是PageA頁面', items: Array.from({length:50}, (v,k) => k), data: '', scrollTop: 0 }; }, beforeRouteEnter(to, from, next) { if(from.name == ’pageB’){ to.meta.isBack = true; } next(); }, mounted() { console.log(’mounted....’); // this指向組件的實(shí)例,$el指向當(dāng)前組件的DOM元素 const $el = this.$el; //滾動事件 $el.addEventListener('scroll', () => { //記錄位置 this.scrollTop = $el.scrollTop; }); }, activated() { if(!this.$route.meta.isBack){ // 如果isBack是false,表明需要獲取新數(shù)據(jù),否則就不再請求,直接使用緩存的數(shù)據(jù) this.getData(); } else { //恢復(fù)滾動條高度 if(this.scrollTop) { setTimeout(() => { this.$el.scrollTop = this.scrollTop; }, 100); } } // 恢復(fù)成默認(rèn)的false,避免isBack一直是true this.$route.meta.isBack = false; }, methods: { getData() { // getData方法,模擬從后臺請求數(shù)據(jù) this.data = '數(shù)據(jù)'; console.log(’get data’) }, goPageB(){ this.$router.push({ path: '/pageB' }); }, back() { this.$router.push({ path: '/' }); } }, }</script><style> .page-a { height: 100vh; overflow-y: auto; } .item { margin: 5px; padding: 10px; background: #ccc; }</style>

代碼請參考 鏈接 ;

后退不刷新還可以通過include實(shí)現(xiàn),可參考鏈接

總結(jié)

到此這篇關(guān)于Vue中keep-alive 實(shí)現(xiàn)后退不刷新并保持滾動位置的文章就介紹到這了,更多相關(guān)keep-alive 后退不刷新持滾動位置內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 二区三区视频 | 亚洲激情专区 | 丝袜天堂 | 97精品国产一区二区三区 | 日韩免费高清视频 | 中文字幕在线一区 | 国产亚洲精品精品国产亚洲综合 | 91精品久久久久久久久中文字幕 | 色呦呦网站 | 精国产品一区二区三区 | 亚洲一区二区三区在线免费观看 | 亚洲精品久久久久久久久久吃药 | 午夜视频一区二区三区 | 国产成人久久av免费高清密臂 | 久久精品国产一区二区三区不卡 | 在线观看日韩 | 特级做a爱片免费69 精品国产鲁一鲁一区二区张丽 | 一区二区成人 | 日韩影院一区 | 免费看片在线播放 | 久久在线| 日韩成人 | 成人三区 | 欧美最猛黑人xxxⅹ 粉嫩一区二区三区四区公司1 | 热re99久久精品国99热观看 | 国产最好的av国产大片 | 亚洲视频在线播放 | 香蕉久久a毛片 | 久久精品成人热国产成 | 免费一区 | 国产日韩精品一区二区 | 国产片侵犯亲女视频播放 | 欧美精品三区 | 日韩在线观看视频一区 | 中文字幕一区二区三区乱码在线 | 日韩欧美精品在线播放 | 亚洲精品9999久久久久 | 国产成人精品综合 | 亚洲成人av在线播放 | 亚洲免费在线播放 | 美女日皮网站 |