国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

Vue生命周期activated之返回上一頁不重新請求數據操作

瀏覽:15日期:2022-12-28 15:38:18

activated: 英文原意:使活動、觸發

在Vue的生命周期函數中,這個好像用的不是特別多?(也許只是在我的工作中這個用的不多,或者說叫幾乎不用這個)

一、需求

前不久在項目中有這樣一個需求:

在訂單頁面的地址信息欄,默認通過接口填充了一個已經設置過的一個的默認地址,現在要跳轉去地址列表重新選擇一個地址并回填到訂單頁面的地址信息位置

二、嘗試

常規操作:

我們通常會將通過接口請求數據的方法放在==created== 或者 ==mounted==這兩個生命周期中的一個里面調用。

但是我們知道,不管是我們剛進入這個頁面還是從其他頁面返回這個頁面,這些生命周期都會走一遍。

問題:

所以,即使你跳轉到下級頁面選好你所需的數據返回上一頁時,你所回填的數據又被從接口請求回來的數據給覆蓋了。。。,這并不是我們想要的效果!!!

三、使用keep-alive

不想讓頁面加載數據???當然可以,這時候==Keep-alive==登場了

vue2.0提供了一個keep-alive組件用來緩存組件,避免多次加載相應的組件,減少性能消耗

1、緩存所有頁面

如果你想緩存所有的頁面,只需要修改下app.vue中的代碼即可

// app.vue <template> <div id='app'> <keep-alive > <router-view></router-view> </keep-alive> <tabBar/> </div> </template>

2、緩存部分頁面

如果你想緩存部分頁面,有兩種方式:

(1)使用router.meta屬性

app.vue

// app.vue <template> <div id='app'> <keep-alive > <router-view v-if='$route.meta.keepAlive'></router-view> </keep-alive> <router-view v-if='!$route.meta.keepAlive'></router-view> <tabBar/> </div> </template>

router.js

{ path: ’/usermanage’, name: ’usermanage’, meta: { keepAlive: true, //該字段表示該頁面需要緩存 }, component: resolve => require([’@/views/userManage/userManage’], resolve) // 路由懶加載 },

(2)使用vue-router 2.0的新特性

2.0提供了include/exclude兩個屬性 可以針對性緩存相應的組件

app.vue

<keep-alive include='a,b'> <router-view></router-view></keep-alive>

==注意==:上面代碼中的a,b是需要緩存的組件的name屬性值,不是路由的name值

使用keep-alive結論

當你第一進入需要緩存的頁面后,頁面數據被緩存下來,但是當你再次進入時,你會發現,頁面的數據還是之前的數據。。。。這也不是我們想要的效果!!!!

四、activated配合keep-alive

首先,我們需要使用router.meta屬性,修改需要緩存的組件路由如下

// keepAlive和isback這兩個很重要!{ path: ’/usermanage’, name: ’usermanage’, meta: { keepAlive: true, //該字段表示該頁面需要緩存 isBack: false, //用于判斷上一個頁面是哪個 title: ’人員管理’ }, component: resolve => require([’@/views/userManage/userManage’], resolve) // 路由懶加載 },

然后修改需要緩存的組件中的代碼(只放重點部分):

<script> export default { name: ’currentName’, data() { return { isFirstEnter: false, // } }, beforeRouteEnter(to, from, next) { if (from.name == ’nextName’) { // 這個name是下一級頁面的路由name to.meta.isBack = true; // 設置為true說明你是返回到這個頁面,而不是通過跳轉從其他頁面進入到這個頁面 } next() }, mounted() { }, activated() { if (!this.$route.meta.isBack || this.isFirstEnter) { this.initData() // 這里許要初始化dada()中的數據 this.getDataFn() // 這里發起數據請求,(之前是放在created或者mounted中,現在只需要放在這里就好了,不需要再在created或者mounted中請求!!) } this.$route.meta.isBack = false //請求完后進行初始化 this.isFirstEnter = false;//請求完后進行初始化 }, }</script>

大功告成

這樣就實現了:從其他頁面跳轉到這個頁面時會請求數據,當從下級頁面返回這個頁面時就不會重新請求數據

以上這篇Vue生命周期activated之返回上一頁不重新請求數據操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 美女在线网站免费的 | 久青草视频在线 | 欧美一级在线 | 萌白酱粉嫩jk福利在线观看 | 中文字幕日韩在线 | 婷婷亚洲久悠悠色在线播放 | 理论视频在线观看 | 午夜综合 | 在线观看香蕉免费啪在线观看 | 日本精品99 | 欧美在线一区二区三区 | 成年大片免费视频播放手机不卡 | 天天看片日本 | 色综合美国色农夫网 | 日韩高清在线不卡 | 欧美日韩中文国产一区二区三区 | 国产欧美综合在线一区二区三区 | 欧美日韩在线国产 | 国产在线观看成人免费视频 | 国产精品日韩欧美一区二区 | 欧美日本高清视频在线观看 | 欧美性高清视频免费看www | 日韩精品另类天天更新影院 | 手机看片久久青草福利盒子 | 99久久www免费| 欧美一级高清片免费一级 | 日韩在线黄色 | 日韩男人的天堂 | 免费看成人www的网站软件 | 亚洲精品国产美女在线观看 | 久久精品中文字幕不卡一二区 | 一级aaa级毛片午夜在线播放 | 亚洲综合精品一区二区三区中文 | 成人亚洲网 | 亚洲国产一区二区三区四区 | 欧美日韩亚洲综合另类ac | 免费人成年短视频在线观看免费网站 | 999国内精品永久免费视频 | 91探花福利精品国产自产在线 | 日韩欧美一区二区三区久久 | 午夜桃色剧场 |