第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

為什么如Vue/小程序/React中都建議在類似于v-for的渲染列表中加入一個(gè)唯一的key?

為什么如Vue/小程序/React中都建議在類似于v-for的渲染列表中加入一個(gè)唯一的key?

桃花長(zhǎng)相依 2019-05-11 09:07:53
題目來源及自己的思路加入了唯一的key的具體作用是什么?在初次渲染列表的時(shí)候,key是否有優(yōu)化的效果?key是在什么時(shí)候產(chǎn)生優(yōu)化的效果的?希望看到這個(gè)小問題,能促進(jìn)思考。###題目描述相關(guān)代碼{{item.name}}
查看完整描述

2 回答

?
三國(guó)紛爭(zhēng)

TA貢獻(xiàn)1804條經(jīng)驗(yàn) 獲得超7個(gè)贊

1、加入key的作用
當(dāng)Vue.js用v-for正在更新已渲染過的元素列表時(shí),它默認(rèn)用“就地復(fù)用”策略。如果數(shù)據(jù)項(xiàng)的順序被改變,Vue將不會(huì)移動(dòng)DOM元素來匹配數(shù)據(jù)項(xiàng)的順序,而是簡(jiǎn)單復(fù)用此處每個(gè)元素,并且確保它在特定索引下顯示已被渲染過的每個(gè)元素。這個(gè)類似Vue1.x的track-by="$index"
引入Vue的官網(wǎng)回答,大概意思就是說,對(duì)已經(jīng)渲染的dom節(jié)點(diǎn),在源列表數(shù)據(jù)部分變化的時(shí)候,不用全部重新渲染dom,只是重新渲染數(shù)據(jù)變化的部分。
2、在初次渲染列表的時(shí)候,key是否有優(yōu)化的效果?沒有優(yōu)化效果。
3、key是在什么時(shí)候產(chǎn)生優(yōu)化的效果的?key是在源數(shù)據(jù)發(fā)生改變的時(shí)候,如果有key,就能追蹤到具體是哪一項(xiàng)或哪幾項(xiàng)數(shù)據(jù)發(fā)生了改變,就能只更新改變數(shù)據(jù)對(duì)應(yīng)的dom。如果你key不唯一的話,vue就很難精確的追蹤到改變的數(shù)據(jù)是哪些了,這也是為什么key必須唯一的原因。
另外,最好不要用列表渲染的index去作為key使用,因?yàn)楫?dāng)源數(shù)據(jù)發(fā)生位置變換,比如說,第一項(xiàng)的數(shù)據(jù)挪到了第二項(xiàng),但是你的key還是不變的,vue為了更新對(duì)視圖,就必須整個(gè)dom重新渲染,等于說白白消耗了很多性能。所以把index當(dāng)做key使用,是完全沒有意義的。
                            
查看完整回答
反對(duì) 回復(fù) 2019-05-11
  • 2 回答
  • 0 關(guān)注
  • 699 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)