日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Vue中keep-alive 實現后退不刷新并保持滾動位置

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

什么是KeepAlive?

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

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

二者的作用簡單來說:

HTTP協議的Keep-Alive意圖在于短時間內連接復用,希望可以短時間內在同一個連接上進行多次請求/響應。

TCP的KeepAlive機制意圖在于保活、心跳,檢測連接錯誤。當一個TCP連接兩端長時間沒有數據傳輸時(通常默認配置是2小時),發送keepalive探針,探測鏈接是否存活。

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

tcp的keepalive是在ESTABLISH狀態的時候,雙方如何檢測連接的可用行。而http的keep-alive說的是如何避免進行重復的TCP三次握手和四次揮手的環節。

正文開始。

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

實現后退不刷新主要依據keep-alive組件的activated和deactivated這兩個生命周期鉤子函數。

vue鉤子函數的執行順序:

不使用keep-alive

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

使用keep-alive

初次進入頁面,beforeRouteEnter --> created --> mounted --> activated --> deactivated

再次進入緩存的頁面,只會觸發beforeRouteEnter -->activated --> deactivated。created和mounted不會再執行。

其中,

activated在keep-alive組件激活時調用.

deactivated在keep-alive組件被停用時調用.

Demo 實現了后退不刷新,并且返回時滾動到上次瀏覽的深度。

該demo中,包含三個鏈接導航。

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

依次前進,每次前進到一個新頁面都需要獲取數據,而按下后退鍵后,

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

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

所以,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指向組件的實例,$el指向當前組件的DOM元素 const $el = this.$el; //滾動事件 $el.addEventListener('scroll', () => { //記錄位置 this.scrollTop = $el.scrollTop; }); }, activated() { if(!this.$route.meta.isBack){ // 如果isBack是false,表明需要獲取新數據,否則就不再請求,直接使用緩存的數據 this.getData(); } else { //恢復滾動條高度 if(this.scrollTop) { setTimeout(() => { this.$el.scrollTop = this.scrollTop; }, 100); } } // 恢復成默認的false,避免isBack一直是true this.$route.meta.isBack = false; }, methods: { getData() { // getData方法,模擬從后臺請求數據 this.data = '數據'; 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實現,可參考鏈接

總結

到此這篇關于Vue中keep-alive 實現后退不刷新并保持滾動位置的文章就介紹到這了,更多相關keep-alive 后退不刷新持滾動位置內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费观看久久av| 电影天堂国产精品| 亚洲欧美日韩高清在线| 桃色av一区二区| 日韩欧美精品一区| 人人香蕉久久| 亚洲国产成人精品女人| 一区在线免费观看| 中文精品电影| 日韩不卡一二三区| 国产精品美女久久久久久不卡| 亚洲精品自拍| 欧美一级网址| 精品国产中文字幕第一页| 国产成人精品福利| 日韩免费在线| 亚洲欧美日韩精品一区二区| 蜜桃视频第一区免费观看| 日本强好片久久久久久aaa| 国产精品theporn| 欧美aa在线视频| 日韩精品电影| 日韩午夜av| 午夜精品福利影院| 国产精品亚洲欧美| 92国产精品| 国产综合欧美| 蜜臀av一区二区在线免费观看| 日韩欧乱色一区二区三区在线| 国产调教精品| 天堂av在线| 在线观看免费一区二区| 少妇精品在线| 精品亚洲a∨| 激情久久久久久| 日日夜夜免费精品| 国产成人精品亚洲线观看| 亚洲成人三区| 日韩av资源网| av资源亚洲| 欧美资源在线| 国产精选久久| 久久精品高清| 日韩精品一级| 麻豆国产在线| 亚洲免费影院| 精品免费av一区二区三区| 欧美精品一区二区三区精品| 亚洲2区在线| 成人高清一区| 在线日韩成人| 国产 日韩 欧美 综合 一区 | 国产欧美高清视频在线| 欧美日韩免费看片| 亚洲一区导航| 精品久久国产一区| 视频在线在亚洲| 国产成人久久| 日韩激情视频网站| 激情综合激情| 你懂的国产精品| 亚洲女人av| 亚洲伊人av| 青青草精品视频| 伊人久久成人| 在线看片福利| 91精品国产一区二区在线观看| 久久视频国产| 亚洲一级淫片| 日韩电影免费网址| 亚洲精品乱码久久久久久蜜桃麻豆| 精品国产午夜肉伦伦影院| 免费欧美在线视频| 在线亚洲人成| 国产情侣久久| 婷婷亚洲五月| 久久精品国产亚洲一区二区三区| 久久亚洲色图| 欧美三区四区| 国产高清精品二区| 视频一区国产视频| 成人免费电影网址| 久久免费精品| 亚洲精品一级二级三级| 久久久噜噜噜| 精品一区视频| 国产亚洲精品美女久久 | 久久伊人亚洲| 视频精品一区| 亚洲一区欧美激情| 日韩精品诱惑一区?区三区| 国产欧美三级| 日韩精品一区第一页| 五月激情久久| 精品久久在线| 国产欧美一区二区三区米奇| 亚洲视频国产| 亚洲一区国产一区| 香蕉人人精品| 亚洲午夜天堂| 91视频精品| 国产一区国产二区国产三区| 国产精品主播| 日韩国产精品久久久久久亚洲| 免费视频久久| 国产视频一区在线观看一区免费| 九色porny丨国产首页在线| 日韩成人a**站| 中文字幕在线看片| 日韩一区自拍| 精品成人免费一区二区在线播放| 国产精品黑丝在线播放| 亚洲精品在线二区| 国产偷自视频区视频一区二区| 丝袜诱惑一区二区| 丝袜国产日韩另类美女| 国产精品亚洲综合在线观看| 日韩国产在线观看| 综合欧美精品| 亚洲区欧美区| 伊人久久亚洲影院| 欧美中文字幕| 亚洲综合图色| 日韩黄色av| 欧美日韩午夜| 欧美激情久久久久久久久久久| 国产精品成人3p一区二区三区| 国产精品嫩模av在线| 日韩av影院| 欧美日本二区| 国产精品1区在线| 久久精品国产精品亚洲毛片| 精品三级av在线导航| 久久99性xxx老妇胖精品| 国产高清视频一区二区| 欧美精品97| 高清不卡亚洲| 久久婷婷一区| 亚洲欧洲午夜| 日韩欧美在线精品| 国产精品调教视频| 超碰99在线| 免费久久久久久久久| 伊人久久亚洲美女图片| 免费成人在线影院| 奇米色欧美一区二区三区| 国产精品调教| 日韩久久精品网| 乱人伦精品视频在线观看| 日韩高清成人在线| 精品美女在线视频| 欧美 日韩 国产精品免费观看| 蜜桃视频第一区免费观看| 国产精品99精品一区二区三区∴| 美女一区网站| 日韩制服丝袜av| 国产精品嫩模av在线| 神马久久午夜| 国产一级久久| 欧美一区免费| 成人日韩在线| 一二三区精品| 日韩av有码| 丝袜美腿成人在线| 久久精品国产精品亚洲毛片| 激情婷婷欧美| 国产日韩三级| 在线一区视频观看| 视频一区二区三区中文字幕| 国产欧美日韩在线一区二区| 国产一区二区精品久| 午夜欧美在线| 国产精品白丝av嫩草影院| 日韩在线高清| 亚洲视频二区| av资源中文在线| 欧美日韩在线观看视频小说| 亚洲二区免费| 99国产精品视频免费观看一公开| 日韩欧美中文字幕在线视频| 国产日韩免费| 亚洲性色av| 亚洲一区免费| 国产精品亚洲产品| 日本а中文在线天堂| 在线国产日韩| 蜜桃久久久久| 中文精品视频| 国产欧美自拍| 亚洲午夜91| 国产欧美在线观看免费| 亚洲欧美伊人| 久久福利在线| 日韩精品一二区| 国产精品毛片久久| 日韩中文字幕视频网| 日本91福利区| 久久影视一区| 日本久久一区| 欧美日韩国产免费观看视频|