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

React中使用collections時(shí)key的重要性詳解

 更新時(shí)間:2017年08月07日 09:51:21   作者:楓上霧棋  
這篇文章主要給大家介紹了關(guān)于在React.js中使用collections時(shí)key的重要性,注意:一定不能不能忘了key,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

大家應(yīng)該都知道,在 React 中 render collections 的 items 時(shí), Keys 扮演著重要的角色, 它直接決定接下來(lái)的 rendered 和 re-rendered,下面話不多說(shuō),來(lái)一起看看詳細(xì)的介紹:

React 不會(huì) render 重復(fù)的 keys

為了徹底明白這個(gè), 我們來(lái)聲明一個(gè)這樣的數(shù)組

const nums = [1, 2, 3, 5, 2]; // 它有兩個(gè)元素的值是相等的

現(xiàn)在, 我們?cè)?react 中來(lái) render

<ul>
 {nums.map(num => <li key={num}>{num}</li>)}
</ul>

這小段代碼構(gòu)造出的理想 element 結(jié)構(gòu), 應(yīng)該是這樣的

<ul>
 <li key="1">1</li>
 <li key="2">2</li>
 <li key="3">3</li>
 <li key="5">5</li>
 <li key="2">2</li>
</ul>

然而, 實(shí)際 DOM 是這樣的

<ul>
 <li>1</li>
 <li>2</li>
 <li>3</li>
 <li>5</li>
</ul>

React 給出了以下warning

 

意思就是, 你必須為數(shù)組中的元素提供唯一的 key 值

React 會(huì) re-render 某個(gè) key 指向的內(nèi)容發(fā)生變化的元素

我們來(lái)看一個(gè)向 users 集合添加 user 的例子

const users = [
 {username:'bob'},
 {username:'sue'}
];

users.map((u, i) =>
 <div key={u.username}>{u.username}</div>);

render 的結(jié)果如下

<div key="bob">bob</div>
<div key="sue">sue</div>

現(xiàn)在, 我們更新一下 users

const users = [
 {username:'joe'},
 {username:'bob'},
 {username:'sue'}
];

render 的結(jié)果將會(huì)改變?nèi)缦?/p>

<div key="joe">joe</div>
<div key="bob">bob</div>
<div key="sue">sue</div>

在上面例子中, React 調(diào)用了它的 Reconciliation 算法, 然后把返回的結(jié)果也就是一個(gè) key 為 sue 的新元素添加到了 users 的最前面

如何選擇 Key

其實(shí), 即使內(nèi)容沒(méi)有發(fā)生變化, 改變對(duì)應(yīng)的 key 值, React 也會(huì)觸發(fā) re-render.

使用 map 函數(shù)的 index 來(lái)作為元素的 key, 對(duì)開(kāi)發(fā)者來(lái)說(shuō)是常見(jiàn)的, 因?yàn)橛袝r(shí)這是必要的, 然而, 有時(shí)這也會(huì)導(dǎo)致性能下降問(wèn)題

users.map((u, i) =>
 <div key={i}>{u.username}</div>);

還是以上的例子, 作了一點(diǎn)小小的改變后, React 瞬間由一個(gè)步驟變成了三個(gè)步驟:

  • 將 id 為 "1" 的元素從 "bob" 更改為 "joe"
  • 將 id 為 "2" 的元素從 "sue" 更改為 "bob"
  • 新增一個(gè) id 為 "3" 的元素, 他的值為 "sue"

總結(jié)

所以, 當(dāng)我們使用 collections 時(shí), 不僅不能忘了 Key, 還要學(xué)會(huì)選擇好的 Key.

好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

原文鏈接: Why you need keys for collections in React

相關(guān)文章

  • 詳解React中合并單元格的正確寫(xiě)法

    詳解React中合并單元格的正確寫(xiě)法

    用表格進(jìn)行頁(yè)面布局,頁(yè)面布局在各種瀏覽器的的兼容性, 本文主要介紹了詳解React中合并單元格的正確寫(xiě)法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • React Fiber與調(diào)和深入分析

    React Fiber與調(diào)和深入分析

    Fiber可以理解為一個(gè)執(zhí)行單元,每次執(zhí)行完一個(gè)執(zhí)行單元,React Fiber就會(huì)檢查還剩多少時(shí)間,如果沒(méi)有時(shí)間則將控制權(quán)讓出去,然后由瀏覽器執(zhí)行渲染操作,這篇文章主要介紹了React Fiber架構(gòu)原理剖析,需要的朋友可以參考下
    2022-11-11
  • React Native自定義組件與輸出方法詳解

    React Native自定義組件與輸出方法詳解

    這篇文章主要給大家介紹了關(guān)于React Native自定義組件與輸出方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • react之組件通信詳解

    react之組件通信詳解

    本篇文章主要介紹了React組件通信詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-10-10
  • antd+react中upload手動(dòng)上傳單限制上傳一張

    antd+react中upload手動(dòng)上傳單限制上傳一張

    本文主要介紹了antd+react中upload手動(dòng)上傳單限制上傳一張,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • react中路由和按需加載的問(wèn)題

    react中路由和按需加載的問(wèn)題

    這篇文章主要介紹了react中路由和按需加載的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • React詳細(xì)講解JSX和組件的使用

    React詳細(xì)講解JSX和組件的使用

    jsx就是javsscript與xml結(jié)合的一種格式,是js語(yǔ)法的一種擴(kuò)展,只要把html代碼寫(xiě)在js中就是jsx。react中定義組件有3種寫(xiě)法:函數(shù)的方式、es5的寫(xiě)法、es6(類(lèi))的寫(xiě)法
    2022-08-08
  • React四級(jí)菜單的實(shí)現(xiàn)

    React四級(jí)菜單的實(shí)現(xiàn)

    本文主要介紹了React四級(jí)菜單的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • react native帶索引的城市列表組件的實(shí)例代碼

    react native帶索引的城市列表組件的實(shí)例代碼

    本篇文章主要介紹了react-native城市列表組件的實(shí)例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • React報(bào)錯(cuò)Too many re-renders解決

    React報(bào)錯(cuò)Too many re-renders解決

    這篇文章主要為大家介紹了React報(bào)錯(cuò)Too many re-renders解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12

最新評(píng)論