成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

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

二者的作用簡單來說:

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

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

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

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

正文開始。

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

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

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

不使用keep-alive

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

使用keep-alive

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

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

其中,

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

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

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

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

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

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

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

從pageB返回到pageA時,pageA不再獲取新數(shù)據(jù),而是使用之前的數(shù)據(jù)。并且當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,表明需要獲取新數(shù)據(jù),否則就不再請求,直接使用緩存的數(shù)據(jù) this.getData(); } else { //恢復滾動條高度 if(this.scrollTop) { setTimeout(() => { this.$el.scrollTop = this.scrollTop; }, 100); } } // 恢復成默認的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實現(xiàn),可參考鏈接

總結

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

標簽: Vue
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲电影在线播放| 69精品人人人人| 91精品国产综合久久久久久漫画| 日韩激情一区二区| 亚洲在线网站| 亚洲午夜免费视频| 亚洲一区二区三区在线观看视频 | 欧美一级二级三级蜜桃| 久久av中文字幕片| 色婷婷综合五月| 天堂影院一区二区| 一本色道久久综合亚洲91| 日本午夜精品一区二区三区电影 | 亚洲视频网在线直播| 亚洲福利免费| 亚洲主播在线观看| 免费国产自线拍一欧美视频| 午夜精品福利一区二区三区av | 亚洲精品成人少妇| 99视频一区| 夜夜精品浪潮av一区二区三区| 亚洲精品乱码久久久久久蜜桃麻豆 | 老司机免费视频一区二区| 欧美色图12p| 韩国一区二区三区| 欧美人狂配大交3d怪物一区| 国产一区二区三区久久久| 91精品国产综合久久久久久漫画| 国产精品99久久久久久宅男| 欧美一区二区三区精品| 成人在线视频一区| 久久九九久久九九| 欧美午夜在线| 亚洲一区中文日韩| 色噜噜狠狠色综合中国| 欧美一个色资源| 97精品国产97久久久久久久久久久久| 欧美国产丝袜视频| 日韩一级网站| 免费国产亚洲视频| 日韩欧美中文字幕一区| 欧美成人在线免费观看| 亚洲精品国产第一综合99久久 | 国产一区二区无遮挡| 亚洲欧美一区二区三区孕妇| 亚洲免费网站| 狂野欧美性猛交blacked| 日韩视频永久免费| 午夜欧美精品| 亚洲午夜三级在线| 欧美日韩三级一区| 91在线视频在线| 一区二区三区中文字幕在线观看| 久久综合久久综合这里只有精品| 国产一区在线精品| 中文字幕 久热精品 视频在线| 国产美女诱惑一区二区| 国产一区二区在线视频| 亚洲国产精品传媒在线观看| 夜久久久久久| 国模套图日韩精品一区二区| 国产欧美日韩不卡免费| 午夜在线播放视频欧美| 国产a区久久久| 亚洲欧美综合另类在线卡通| 色吊一区二区三区| 91丨九色丨蝌蚪丨老版| 亚洲成人激情av| 日韩欧美在线一区二区三区| 亚洲私人影院| 美女性感视频久久| 精品va天堂亚洲国产| 国产精品久久久久毛片大屁完整版| 久久成人免费网| 久久精品视频在线免费观看| 亚洲在线视频| 成人激情小说网站| 亚洲图片一区二区| 精品国产乱码久久久久久蜜臀| 国产精品美女| 不卡的av网站| 亚洲国产欧美在线| 欧美zozozo| 美女主播一区| 欧美一区1区三区3区公司| 午夜精品一区二区三区免费视频 | 欧美日韩在线精品一区二区三区| 婷婷开心久久网| 久久蜜桃香蕉精品一区二区三区| 国产精品综合色区在线观看| 国产99一区视频免费| 亚洲免费毛片网站| 精品久久久久99| 色中色一区二区| 欧美一区二区在线| 青青草国产成人av片免费| 国产欧美视频一区二区三区| 色呦呦一区二区三区| av亚洲精华国产精华精华| 亚洲高清免费视频| 久久久九九九九| 欧美天堂一区二区三区| 亚洲精品美女91| 成+人+亚洲+综合天堂| 丝袜诱惑亚洲看片| 国产精品区一区二区三区| 欧美丰满少妇xxxbbb| 亚洲一区二区三区欧美| 91视频观看免费| 激情成人午夜视频| 亚洲高清视频的网址| 欧美经典一区二区| 欧美一区在线视频| 国产精品久久九九| 欧美日韩一区二区三| 国产精品一二三| 午夜精品影院在线观看| 国产精品高潮久久久久无| 日韩精品在线看片z| 色婷婷久久久久swag精品| 亚洲国产精品一区| 99精品视频在线观看| 极品少妇xxxx精品少妇| 亚洲最大成人网4388xx| 国产日韩亚洲欧美综合| 日韩欧美一级片| 欧美日韩一级片在线观看| 国产伦理一区| 亚洲天堂久久| 99re8在线精品视频免费播放| 久久精品国产99久久6| 亚洲主播在线观看| 中文字幕一区二区在线播放 | 国产精品久久久久久亚洲伦| 日韩精品一区二区三区在线观看| 欧美性xxxxxxxx| 久久精品中文字幕一区二区三区| 伊人久久婷婷色综合98网| 欧美国产一区二区三区激情无套| 国产成人精品在线看| 寂寞少妇一区二区三区| 水蜜桃久久夜色精品一区的特点| 亚洲精品日日夜夜| 国产精品久久久久影院色老大| 久久先锋影音av鲁色资源网| 91精品欧美一区二区三区综合在| 欧美视频完全免费看| 欧美在线一二三| 在线一区二区观看| 久久字幕精品一区| 噜噜噜躁狠狠躁狠狠精品视频| 99国产精品| 亚洲欧洲日本mm| 在线不卡视频| 亚洲电影专区| 日韩一级大片| 亚洲二区精品| 伊人蜜桃色噜噜激情综合| 欧美日韩国产三区| 91蜜桃免费观看视频| 色综合网色综合| 色综合一区二区三区| 亚洲欧美影院| 午夜精品区一区二区三| 91丨porny丨国产| 女同性一区二区三区人了人一| 99久免费精品视频在线观看 | 韩国视频一区二区| 久久99精品国产麻豆婷婷洗澡| 丝瓜av网站精品一区二区| 午夜日韩在线电影| 日韩精品国产精品| 麻豆精品一区二区综合av| 久久机这里只有精品| 欧美日韩一级视频| 欧美日韩视频一区二区三区| 亚洲高清免费视频| 91精品国产欧美日韩| 国产不卡一区视频| 中文字幕第一页久久| 久草热8精品视频在线观看| 欧美亚洲动漫精品| 久久国产精品色婷婷| av成人黄色| 亚洲麻豆国产自偷在线| 久久久久久久久一| 91久久久久| 国产日韩欧美一区| 亚洲精品在线视频观看| 国产精品一区二区欧美| 久久亚洲免费| 欧美日韩国产高清一区| 91精品国产日韩91久久久久久| 日韩免费福利电影在线观看| 精品久久久久久无| 欧美极品少妇xxxxⅹ高跟鞋| 亚洲欧洲日韩在线| 亚洲自拍与偷拍| 喷白浆一区二区| 久久99国产精品成人|