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

react為什么不推薦使用index作為key

 更新時(shí)間:2021年07月22日 11:43:15   作者:JQ...  
本文主要介紹了react為什么不推薦使用index作為key,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

1.舊的虛擬dom和新的虛擬dom對(duì)比,首先看他們的key是否相同
2.相同繼續(xù)對(duì)比他們的內(nèi)容,不同生成新的真實(shí)dom進(jìn)行替換
3.如果內(nèi)容和key都相同,復(fù)用舊的真實(shí)dom 不做改變

那么如果我們使用遍歷時(shí)候自動(dòng)生成的index作為每個(gè)節(jié)點(diǎn)的key可能會(huì)出現(xiàn)什么問(wèn)題呢? 下面放個(gè)小案例

首先,初始時(shí)我們進(jìn)行遍歷persons

他會(huì)是這樣一個(gè)過(guò)程,源數(shù)據(jù)

persons: [
{ id: 1, name: “張三”, age: 15 },
{ id: 2, name: “李四”, age: 16 },
],

生成的真實(shí)dom節(jié)點(diǎn)

<ul>
      <li key="0">張三--15</li>
      <li key="1">李四--16</li>
    </ul>

然后我們?cè)谶@個(gè)名單前面插入一個(gè){id:3,name:‘王五',age:14}的數(shù)據(jù)會(huì)變成這樣子

<ul>
   <li key="0">王五--14</li>
      <li key="1">張三--15</li>
      <li key="2">李四--16</li>
    </ul>

通過(guò)上面的更新可以發(fā)現(xiàn) 王五將之前張三的key給占用了
也就是說(shuō)當(dāng)我進(jìn)行更新這一過(guò)程首先新的虛擬dom

<li key="0">王五--14</li>

和舊的虛擬dom

<li key="0">張三--15</li>

進(jìn)行比較 新的dom先比較key兩人相同,在比較內(nèi)容一個(gè)是王五–14 一個(gè)是張三15 ,內(nèi)容發(fā)生變化了,這時(shí)就會(huì)進(jìn)行使用新的虛擬dom生成新的真是dom重新渲染頁(yè)面,而且不僅是之前的張三受影響需要重新生成,后面的李四也要被張三進(jìn)行替換在生成一個(gè)新的內(nèi)容為張三的真實(shí)dom,這樣就會(huì)導(dǎo)致所有的dom都要重新生成重新渲染,導(dǎo)致性能下降

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script src="https://unpkg.com/react@16/umd/react.development.js"></script>
    <script src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script>
    <script src="https://unpkg.com/babel-standalone@6.26.0/babel.js"></script>

    <div id="root"></div>
    <script type="text/babel">
      let root = document.getElementById("root");
      class App extends React.Component {
        constructor(props) {
          super(props);
        }
        state = {
          persons: [
            { id: 1, name: "張三", age: 15 },
            { id: 2, name: "李四", age: 16 },
          ],
        };
        handle = () => {
          const { persons } = this.state;
          const p = {
            id: 0,
            name: "王五",
            age: 14,
          };
          this.setState({
            persons: [p, ...persons],
          });
        };
        render() {
          return (
            <div>
              <button onClick={this.handle}>點(diǎn)擊添加</button>
              <ul>
                {this.state.persons.map((person, index) => (
                  <li key={index}>
                    {person.name}--{person.age}
                  </li>
                ))}
              </ul>
            </div>
          );
        }
      }
      ReactDOM.render(<App name="hell" />, root);
    </script>
  </body>
</html>

試想一下經(jīng)過(guò)上面的推導(dǎo)致,如果我們使用id作為唯一的key值會(huì)怎么樣呢

更新前

<ul>
      <li key="1">張三--15</li>
      <li key="2">李四--16</li>
    </ul>

更新后

<ul>
   <li key="0">王五--14</li>
      <li key="1">張三--15</li>
      <li key="2">李四--16</li>
    </ul>

這次 雖然王五插入的還是張三的前面但是只對(duì)比了一次 王五和上面是否有一樣的key=0的節(jié)點(diǎn) ,沒(méi)有生成新的真實(shí)dom進(jìn)行渲染,而張三和上面key=1的進(jìn)行對(duì)比,發(fā)現(xiàn)上面有一個(gè)key=1的節(jié)點(diǎn),然后再對(duì)比他們的內(nèi)容是否相同,發(fā)現(xiàn)內(nèi)容也相同,那么就可以復(fù)用舊的真實(shí)dom,節(jié)約性能

到此這篇關(guān)于react為什么不推薦使用index作為key的文章就介紹到這了,更多相關(guān)react index作為key內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • react+antd樹(shù)選擇下拉框中增加搜索框

    react+antd樹(shù)選擇下拉框中增加搜索框

    這篇文章主要介紹了react+antd樹(shù)選擇下拉框中增加搜索框方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Electron整合React使用搭建開(kāi)發(fā)環(huán)境的步驟詳解

    Electron整合React使用搭建開(kāi)發(fā)環(huán)境的步驟詳解

    這篇文章主要介紹了Electron整合React使用搭建開(kāi)發(fā)環(huán)境,本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2020-06-06
  • react高階組件添加和刪除props

    react高階組件添加和刪除props

    這篇文章主要介紹了react高階組件添加和刪除props,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 詳解如何在React中有效地監(jiān)聽(tīng)鍵盤(pán)事件

    詳解如何在React中有效地監(jiān)聽(tīng)鍵盤(pán)事件

    React是一種流行的JavaScript庫(kù),用于構(gòu)建用戶(hù)界面,它提供了一種簡(jiǎn)單而靈活的方式來(lái)創(chuàng)建交互式的Web應(yīng)用程序,在React中,我們經(jīng)常需要監(jiān)聽(tīng)用戶(hù)的鍵盤(pán)事件,以便根據(jù)用戶(hù)的輸入做出相應(yīng)的反應(yīng),本文將向您介紹如何在React中有效地監(jiān)聽(tīng)鍵盤(pán)事件,并展示一些常見(jiàn)的應(yīng)用場(chǎng)景
    2023-11-11
  • React?Context詳解使用方法

    React?Context詳解使用方法

    Context提供了一個(gè)無(wú)需為每層組件手動(dòng)添加props,就能在組件樹(shù)間進(jìn)行數(shù)據(jù)傳遞的方法。在一個(gè)典型的?React?應(yīng)用中,數(shù)據(jù)是通過(guò)props屬性自上而下(由父及子)進(jìn)行傳遞的,但這種做法對(duì)于某些類(lèi)型的屬性而言是極其繁瑣的
    2022-12-12
  • React中的生命周期詳解

    React中的生命周期詳解

    這篇文章主要介紹了React中的生命周期,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-09-09
  • React中useState原理的代碼簡(jiǎn)單實(shí)現(xiàn)

    React中useState原理的代碼簡(jiǎn)單實(shí)現(xiàn)

    要實(shí)現(xiàn)useState的背后原理,則需要深入了解狀態(tài)是如何在函數(shù)組件的渲染周期中保持和更新的,本文將通過(guò)一段代碼簡(jiǎn)單闡述useState鉤子函數(shù)的實(shí)現(xiàn)思路,希望對(duì)大家有所幫助
    2023-12-12
  • React事件處理和表單的綁定詳解

    React事件處理和表單的綁定詳解

    這篇文章主要介紹了React事件處理和表單的綁定,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • React html中使用react的兩種方式

    React html中使用react的兩種方式

    這篇文章主要介紹了React html中使用react的兩種方式,本文給大家提到了React pwa的配置代碼,給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • react-router-domV6版本的路由和嵌套路由寫(xiě)法詳解

    react-router-domV6版本的路由和嵌套路由寫(xiě)法詳解

    本文主要介紹了react-router-domV6版本的路由和嵌套路由寫(xiě)法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論