电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:132日期: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
相關文章:
主站蜘蛛池模板: 彼得逊采泥器-定深式采泥器-电动土壤采样器-土壤样品风干机-常州索奥仪器制造有限公司 | 车辆定位管理系统_汽车GPS系统_车载北斗系统 - 朗致物联 | 博博会2021_中国博物馆及相关产品与技术博览会【博博会】 | 旋转/数显粘度计-运动粘度测定仪-上海平轩科学仪器 | 贵州水玻璃_-贵阳花溪闽兴水玻璃厂 | 磁粉制动器|张力控制器|气胀轴|伺服纠偏控制器整套厂家--台灵机电官网 | 扒渣机厂家_扒渣机价格_矿用扒渣机_铣挖机_撬毛台车_襄阳永力通扒渣机公司 | 亿诺千企网-企业核心产品贸易 | 超声骨密度仪-骨密度检测仪-经颅多普勒-tcd仪_南京科进实业有限公司 | 合肥升降机-合肥升降货梯-安徽升降平台「厂家直销」-安徽鼎升自动化科技有限公司 | 培训中心-翰香原香酥板栗饼加盟店总部-正宗板栗酥饼技术 | 镀锌方管,无缝方管,伸缩套管,方矩管_山东重鑫致胜金属制品有限公司 | 上海道勤塑化有限公司| 电缆桥架生产厂家_槽式/梯式_热镀锌线槽_广东东莞雷正电气 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 | 注塑机-压铸机-塑料注塑机-卧式注塑机-高速注塑机-单缸注塑机厂家-广东联升精密智能装备科技有限公司 | 焦作网 WWW.JZRB.COM| 厦门网站建设_厦门网站设计_小程序开发_网站制作公司【麦格科技】 | 合肥礼品公司-合肥礼品定制-商务礼品定制公司-安徽柏榽商贸有限公司 | 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 成都珞石机械 - 模温机、油温机、油加热器生产厂家 | 十二星座查询(性格特点分析、星座运势解读) - 玄米星座网 | 南京PVC快速门厂家南京快速卷帘门_南京pvc快速门_世界500强企业国内供应商_南京美高门业 | 餐饮小吃技术培训-火锅串串香培训「何小胖培训」_成都点石成金[官网] | 宠物店加盟_宠物连锁店_开宠物店-【派多格宠物】 | 胃口福饺子加盟官网_新鲜现包饺子云吞加盟 - 【胃口福唯一官网】 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 南京种植牙医院【官方挂号】_南京治疗种植牙医院那个好_南京看种植牙哪里好_南京茀莱堡口腔医院 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 地磅-电子地磅维修-电子吊秤-汽车衡-无人值守系统-公路治超-鹰牌衡器 | 渗透仪-直剪仪-三轴仪|苏州昱创百科 | 磷酸肌酸二钠盐,肌酐磷酰氯-沾化欣瑞康生物科技 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 深圳办公室装修,办公楼/写字楼装修设计,一级资质 - ADD写艺 | 植筋胶-粘钢胶-碳纤维布-碳纤维板-环氧砂浆-加固材料生产厂家-上海巧力建筑科技有限公司 | 组织研磨机-高通量组织研磨仪-实验室多样品组织研磨机-东方天净 传递窗_超净|洁净工作台_高效过滤器-传递窗厂家广州梓净公司 | 超声波焊接机_超音波熔接机_超声波塑焊机十大品牌_塑料超声波焊接设备厂家 | 干粉砂浆设备-干粉砂浆生产线-干混-石膏-保温砂浆设备生产线-腻子粉设备厂家-国恒机械 | 钢衬玻璃厂家,钢衬玻璃管道 -山东东兴扬防腐设备有限公司 | 安规_综合测试仪,电器安全性能综合测试仪,低压母线槽安规综合测试仪-青岛合众电子有限公司 | 橡胶接头_橡胶软接头_套管伸缩器_管道伸缩器厂家-巩义市远大供水材料有限公司 | 小程序开发公司-小程序制作-微信小程序开发-小程序定制-咏熠软件 |