溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Vue動態(tài)路由緩存不相互影響的解決辦法

發(fā)布時(shí)間:2020-09-19 06:40:41 來源:腳本之家 閱讀:212 作者:冬日夜已眠 欄目:web開發(fā)

關(guān)于react與vue中的key

之前在學(xué)習(xí)react的時(shí)候,常常遇到循環(huán)渲染組件時(shí)會提示需要在循環(huán)組件中加上key屬性,比如有一組列表:

import React, { Component } from 'react';

export default calss MainApp extends Component {
 state = {
  student: [
  {
   name: 'Jenny',
   id: 'a001'
  },
  {
   name: 'Jerry',
   id: 'a002'
  },
  ]
 }

 render() {
  return (
   <div>
     <ul>
     {
      this.state.student.map(item => {
       // key是必須的屬性,不然瀏覽器會拋出錯誤提示
       return (<li key={item.id}>{item.name}</li>) 
      })
     }
     </ul>
    </div>
  )
 }
}

可能對這個key不是太了解,或者也不許要太深入地去了解它,只知道在循環(huán)渲染組件時(shí),隨手加上這個屬性就好。摘自網(wǎng)上的的文章的總結(jié),key的作用為

key的作用主要是為了高效的更新虛擬DOM

雖然不是很懂,但也裝作大切大悟的樣子。key是一個給框架內(nèi)部用的,我們只管給它加上去就好。

Vue中的key

同樣有一個vue的組件:

<template>
 <div>
  <ul>
   <!-- key是必須的屬性,不然瀏覽器會拋出錯誤提示 -->
   <li v-for="itme in student" :key={item.id}>{{item.name}}</li>
  </ul>
 </div>
</template>

<script>
import vue from 'vue';
import { Component } from 'vue-property-decorator'

@Component
export default calss MainApp extends vue {
 student = [
  {
   name: 'Jenny',
   id: 'a001'
  },
  {
   name: 'Jerry',
   id: 'a002'
  },
 ]
}
</script>

同樣的,回到vue中的key,其實(shí)也類似,解釋key的作用,就不得不介紹一下虛擬DOM的diff算法了...算了,我也不是很懂
簡單理解就是react與vue內(nèi)部判斷組件的一個標(biāo)識,用于更新或者重用組件的一個重要屬性

更新

key用于更新:是框架內(nèi)部的算法實(shí)現(xiàn),一兩句話也說不清楚(主要是我也不懂這個算法),簡單理解為當(dāng)數(shù)據(jù)更新了,框架內(nèi)部會判斷更新頁面哪些DOM元素需要更新刪除等操作;

重用

key用于組件重用:其實(shí)key不止是在map或者v-for中使用,我們也也可以在其他組件上使用這個屬性(至于哪個組件可以加,小孩子才做選擇,我們的目標(biāo)是全都加?。?當(dāng)然加了貌似也沒什么毛病,只是加了顯得有些多余!
在做SPA的時(shí)候,我們都會有一個主組件App.vue:

<template>
 <div id="app">
  <div>
   <keep-alive>
    <router-view />
   </keep-alive>
  </div>
 </div>
</template>

<script>
import Vue from 'vue'
import { Component } from 'vue-property-decorator'

@Component
export default class MainApp extends Vue {
 
}
</script>

上面代碼會把頁面全部都緩存下來(路由切換回來的時(shí)候,頁面表單填寫的內(nèi)容沒有被清空),這是應(yīng)為在<router-view />的外面包裹著keep-alive標(biāo)簽, 頁面數(shù)據(jù)都保留下來了,避免用戶切換路由,數(shù)據(jù)丟失的情況,看似很完美!

比如一個產(chǎn)品頁面:

當(dāng)兩個路由都使用同一個組件如Product.vue這個組件時(shí),來回切換兩個路由,兩個頁面填寫的東西就會共用!切換頁面時(shí),發(fā)現(xiàn)頁面自動填寫了上個頁面的東西,這并不是我們想要的!

如果頁面比較少, 比如只有A、B兩個產(chǎn)品,可以每個頁面都定義一個路由地址,并且name屬性不一樣的值:

{
 path: '/product',
 name: 'product',
 component: Product,
 children: [
  {
   path: 'a',
   name: 'aProduct',
   component: Detail
  },
  {
   path: 'b',
   name: 'bProduct',
   component: Detail
  },
 ]
}

這時(shí)這樣<router-view :key="$route.name"/>就解決上面的問題了

But,頁面較多的時(shí)候,定義路由就不能像上面這樣定義了:

{
 path: '/product',
 name: 'product',
 component: Product,
 children: [
  {
   path: 'detail/:id',
   name: 'aProduct',
   component: Detail
  },
 ]
}

此時(shí)路由變成了動態(tài)的了,那么,key就不能取name的值了,此時(shí)就需要引入一個變量來存儲路由的歷史記錄了,當(dāng)路由切換時(shí),在歷史記錄中匹配相應(yīng)的路由,在歷史記錄中保存的一個位置值,取出來賦值個key就可以了

嗯,前面好像廢話有點(diǎn)多,而且貌似有騙標(biāo)題的嫌疑,其實(shí)理解key這個屬性,對于解決頁面緩存,組件重復(fù)不相互影響有重要的作用。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI