欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue-router數(shù)據(jù)加載與緩存使用總結(jié)

 更新時間:2018年10月29日 09:21:40   作者:_west  
這篇文章主要介紹了詳解vue-router數(shù)據(jù)加載與緩存使用總結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

之前開發(fā)了一個單頁面應(yīng)用,按照深度,分為三層:目錄頁、一級子頁(標簽頁、故事頁等)、二級子頁(故事編輯頁)。

這三類頁面都共享一個完整的數(shù)據(jù)model,從上級頁面進入下一級頁面時,能夠加載相應(yīng)數(shù)據(jù);回到上一級時,數(shù)據(jù)有更新。舉個栗子,從故事頁點擊“編輯”按鈕,進入故事編輯頁則默認填充點擊的“編輯”按鈕所對應(yīng)的故事數(shù)據(jù);而當在故事編輯頁更新數(shù)據(jù),返回到故事頁時,剛剛更新的信息也能在故事頁展示。

對于這項需求,我們需要解決如下幾個問題:

  • 三層頁面共享數(shù)據(jù);
  • 進入或退回當前路由時,數(shù)據(jù)更新;
  • 對于故事列表頁,返回時保留之前瀏覽位置;

本文后面內(nèi)容,將對如上問題一一提出解決方案。

共享數(shù)據(jù)

多個路由共享數(shù)據(jù),可以使用vuex做數(shù)據(jù)中心,由于需求對數(shù)據(jù)處理并不復(fù)雜,為了簡便就使用window全局對象作為路由間傳遞數(shù)據(jù)的工具。
核心數(shù)據(jù)我們可以設(shè)計為如下結(jié)構(gòu),以故事為例:

window.profileData = {
 storyList: [{
  content: 'xxx',
  type: 0,
  picList: [...],
 }, ...],
 description: {...}, // 其他字段數(shù)據(jù)
}

注意到,如果需要更新storyList,則應(yīng)該使用能夠被檢測到的方法,如push, splice等。

數(shù)據(jù)更新與緩存

數(shù)據(jù)更新與緩存大致有兩種方案:

第一種,利用vue-router的導航守衛(wèi)(見文檔:https://router.vuejs.org/zh/guide/advanced/navigation-guards.html),主要使用路由組件內(nèi)導航 beforeRouteEnter 和 beforeRouteLeave;

第二種,在路由組件中監(jiān)聽$route,每次路由變化就會調(diào)用其中方法加載數(shù)據(jù),需要注意的是第一次進入路由組件$route的監(jiān)聽不會觸發(fā),我們需要在mounted方法中調(diào)用相同加載數(shù)據(jù)的方法;

我們在代碼中使用的是方法一,以故事列表進入到故事編輯頁為例,從列表傳遞index給編輯頁,利用beforeRouteEnter進入路由時就加載新的數(shù)據(jù)。

編輯頁中關(guān)鍵代碼,即加載數(shù)據(jù)、更新本地共享數(shù)據(jù):

export default {
 // 編輯頁中, 進入路由前加載數(shù)據(jù)
 beforeRouteEnter(to, from, next) {
  next(vm => {
   const index = vm.$route.params.storyIndex
   vm.storyIndex = index
   vm.storyData = window.profile.storyList[index]
  })
 },

 methods: {
  // 提交成功后,更新本地共享數(shù)據(jù)
  submit() {
   Adapter.post('...').then(result => {
    window.profile.storyList.splice(this.storyIndex, 1, result)
   }) 
  },
 },
}

列表頁中關(guān)鍵代碼,即返回時更新數(shù)據(jù):

export default {
 beforeRouteEnter(to, from, next) {
  next(vm => {
   vm.storyList = window.profileData.storyList
  })
 },
}

這部分需要注意的有兩點:

  • beforeRouteEnter中無法調(diào)用組件實例,因為執(zhí)行時還在組件生命周期的beforeCreate之前,而其中的next方法是在組件mounted之后執(zhí)行,如需引用可在next方法中,引用其參數(shù),該參數(shù)就是組件實例;
  • 如果發(fā)現(xiàn)你的next方法無法執(zhí)行,請升級到2.6+版本,之前的版本這部分有些問題;

保留瀏覽位置

從故事編輯頁回到故事列表頁,我們希望可以保存之前瀏覽的位置。思路也很簡單,進入編輯頁時保存scrollTop,返回時scrollTo即可。而且vue-router對象有屬性可以實現(xiàn)這個功能,這就簡潔多了。

由于我們過渡動畫中間,有將路由組件定位成fixed的操作,所以,動畫結(jié)束后再手動滾動到目標位置:

new VueRouter({
 routes,
 scrollBehavior (to, from, savedPosition) {
  const y = savedPosition && savedPosition.y || 0
  setTimeout(() => { window.scrollTo(0, y) }, 300)
 }
})

總結(jié)

vue-router我們在偏B端的場景中經(jīng)常用到,尤其是分步驟填寫表單的頁面。前期在使用過程中總是不太順暢,摸索幾次后,最終找到比較“舒適”的使用方法,索性就梳理成文。
當然,還有其他一些特殊場景的用法,這里暫時不說了,等項目中用過后再另起一文,繼續(xù)研究。

參考文獻

1. 《官方文檔》
2. 《滾動行為》

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue中vxe-table虛擬滾動列表的使用詳解

    vue中vxe-table虛擬滾動列表的使用詳解

    vxe-table 是一個功能強大的 Vue 表格組件,它支持虛擬滾動列表作為其核心功能之一,本文主要介紹一下vxe-table的虛擬滾動列表功能的使用場景和優(yōu)勢,感興趣的可以了解下
    2023-12-12
  • vue-router的鉤子函數(shù)用法實例分析

    vue-router的鉤子函數(shù)用法實例分析

    這篇文章主要介紹了vue-router的鉤子函數(shù)用法,結(jié)合實例形式分析了vue路由鉤子分類及vue-router鉤子函數(shù)相關(guān)使用技巧,需要的朋友可以參考下
    2019-10-10
  • vue實現(xiàn)移動端省市區(qū)選擇

    vue實現(xiàn)移動端省市區(qū)選擇

    這篇文章主要為大家詳細介紹了vue實現(xiàn)移動端省市區(qū)選擇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • SpringBoot+Vue3實現(xiàn)上傳文件功能

    SpringBoot+Vue3實現(xiàn)上傳文件功能

    這篇文章主要介紹了SpringBoot+Vue3實現(xiàn)上傳文件功能,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • 詳解Vue的列表渲染

    詳解Vue的列表渲染

    這篇文章主要為大家介紹了Vue的列表渲染,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • vue+canvas實現(xiàn)數(shù)據(jù)實時從上到下刷新瀑布圖效果(類似QT的)

    vue+canvas實現(xiàn)數(shù)據(jù)實時從上到下刷新瀑布圖效果(類似QT的)

    這篇文章主要介紹了vue+canvas實現(xiàn)數(shù)據(jù)實時從上到下刷新瀑布圖效果(類似QT的),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • 在vue中使用echarts(折線圖的demo,markline用法)

    在vue中使用echarts(折線圖的demo,markline用法)

    這篇文章主要介紹了在vue中使用echarts(折線圖的demo,markline用法),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 基于vue2.0+vuex+localStorage開發(fā)的本地記事本示例

    基于vue2.0+vuex+localStorage開發(fā)的本地記事本示例

    這篇文章主要介紹了基于vue2.0+vuex+localStorage開發(fā)的本地記事本示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-02-02
  • vue3基于script?setup語法$refs的使用

    vue3基于script?setup語法$refs的使用

    這篇文章主要介紹了vue3基于script?setup語法$refs的使用,<BR>?在用vue3開發(fā)項目的時候,需要調(diào)用子組件的方法,于是想著用$refs來實現(xiàn),但是我是使用script?setup語法糖,原先vue2的語法已經(jīng)不適用了。下面我們一起進入文章看詳細內(nèi)容吧</P><P>
    2021-12-12
  • 某些場景下建議vue query代替pinia原理解析

    某些場景下建議vue query代替pinia原理解析

    這篇文章主要為大家介紹了某些場景下建議vue-query代替pinia原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02

最新評論