> 웹 프론트엔드 > JS 튜토리얼 > 반응에서 키의 구체적인 사용 소개(코드 예)

반응에서 키의 구체적인 사용 소개(코드 예)

不言
풀어 주다: 2018-11-27 15:51:03
앞으로
1908명이 탐색했습니다.

이 글은 React에서의 구체적인 키 사용법을 소개합니다. (코드 예제) 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

반응에서 키의 구체적인 사용 소개(코드 예)

우리는 리액트 프로그램을 개발할 때 이런 경고를 자주 접하고는 다음과 같은 생각을 합니다. 루프 하위 컴포넌트에 키를 추가하는 걸 깜빡했어요~

편의상 가끔 별 생각 없이 루프의 인덱스를 키로 사용하는 경우가 있는데 이게 정말 좋은 걸까요? 키에 가장 적합한 값은 무엇입니까?

이해를 돕기 위해 이 글에서는 "키"를 세 가지 측면에서 분석합니다.

1. 키를 사용하는 이유

2. 인덱스를 키로 사용할 때 발생하는 문제

3. 사용하는 이유 keys

react 공식 문서에서는 키를 다음과 같이 설명합니다.

Keys는 DOM의 특정 요소가 추가되거나 삭제될 때 React가 어떤 요소가 변경되었는지 식별하는 데 도움이 될 수 있습니다. 따라서 배열의 각 요소에 특정 ID를 부여해야 합니다.

React의 diff 알고리즘은 키를 고유 ID로 처리한 다음 구성 요소의 값을 비교하여 업데이트가 필요한지 결정합니다. 따라서 키가 없으면 React는 구성 요소를 업데이트하는 방법을 알 수 없습니다.

키를 전달하지 않고도 사용할 수 있습니다. 왜냐하면 React가 하위 구성 요소에 키가 없음을 감지한 후 기본적으로 배열의 인덱스를 키로 사용하기 때문입니다.

React는 키를 기반으로 구성 요소를 삭제, 재생성 또는 업데이트할지 결정합니다. 원칙은 다음과 같습니다.

키는 동일하며 구성 요소가 변경되면 React는 구성 요소의 해당 속성만 업데이트합니다.
  • 키가 다르면 구성 요소가 이전 구성 요소를 삭제하고 전체 구성 요소를 다시 렌더링합니다.
  • 2. 인덱스를 키로 사용할 때 발생하는 문제

2.1 제어되는 구성요소

span과 같은 간단한 표시 구성요소는 제어되는 구성요소이므로 해당 값은 우리가 제공한 값이 됩니다.

하위 컴포넌트가 컨트롤 컴포넌트일 뿐이고 인덱스를 키로 사용하는 경우 표면적으로는 문제가 없을 수 있지만 실제로는 성능에 큰 영향을 미치게 됩니다. 예를 들어 다음 코드는

// ['张三','李四','王五']=>
로그인 후 복사
로그인 후 복사
        
  • 张三
  •     
  • 李四
  •     
  • 王五
// 数组重排 -> ['王五','张三','李四'] =>
        
  • 王五
  •     
  • 张三
  •     
  • 李四
요소 데이터 소스의 순서가 변경되면 해당하는

키가 0, 1, 2인 구성 요소가 모두 변경되고 세 가지 하위 구성 요소가 모두 다시 렌더링됩니다. (여기서 다시 렌더링하는 것은 키가 여전히 있기 때문에 파괴되지 않습니다.)

대신 고유 ID를 키로 사용합니다:

// ['张三','李四','王五']=>
로그인 후 복사
로그인 후 복사
        
  • 张三
  •     
  • 李四
  •     
  • 王五
// 数组重排 -> ['王五','张三','李四'] =>
        
  • 王五
  •     
  • 张三
  •     
  • 李四
위 업데이트 원칙에 따르면 하위 구성 요소의 값과 키는 변경되지 않았습니다. 순서가 변경되었기 때문에 React는 이동만 하고 다시 렌더링하지 않았습니다.

2.2 제어되지 않는 구성 요소

입력과 같이 사용자가 임의로 값을 변경할 수 있고 당사에서 제어할 수 없는 구성 요소는 인덱스를 키로 사용할 때 문제를 일으킬 수 있습니다.

하위 구성 요소:

  render() {
    return (
      <p>
        </p><p>值:{this.props.value}</p>
        <input>
      
    );
  }
}
로그인 후 복사
상위 구성 요소

{
this.state.data.map((element, index) => {
    return <child></child>
    })
}
로그인 후 복사
처음 두 개의 입력 상자에 해당 값을 입력합니다:

반응에서 키의 구체적인 사용 소개(코드 예) 그런 다음 헤드에 요소를 추가합니다:

반응에서 키의 구체적인 사용 소개(코드 예)분명히 이 결과는 우리에게 적합하지 않습니다. 예상대로 , 무슨 일이 일어났는지 분석해 봅시다:

<div>
    <p>值:0</p>
    <input>
</div>
<div>
    <p>值:1</p>
    <input>
</div>
<div>
    <p>值:2</p>
    <input>
</div>
로그인 후 복사
변경 후:

    

值:5

    
<div>     <p>值:0</p>     <input> </div> <div>     <p>值:1</p>     <input> </div> <div>     <p>值:2</p>     <input> </div>
로그인 후 복사
다음을 확인할 수 있습니다: 키 0, 1, 2는 변경되지 않았습니다. 규칙에 따라 구성 요소는 제거되지 않으며 변경된 속성만 삭제됩니다. 업데이트되었습니다.

react는 p 태그 값의 변경 사항만 비교하고 입력 상자의 값은 변경되지 않았으므로 다시 렌더링되지 않으며 p 태그 값만 업데이트됩니다.

고유 ID를 키로 사용한 후:

<div key="000">
    <p >值:0</p>
    <input />
</div>
<div key="111">
    <p >值:1</p>
    <input />
</div>
<div key="222">
    <p >值:2</p>
    <input />
</div>
로그인 후 복사
반응에서 키의 구체적인 사용 소개(코드 예)변경 후:

值:5

<div key="000"> <p >值:0</p> <input /> </div> <div key="111"> <p >值:1</p> <input /> </div> <div key="222"> <p >值:2</p> <input /> </div>
로그인 후 복사

키가 111, 222, 333인 구성 요소는 변경되지 않았으며 반응이 업데이트되지 않음을 분명히 알 수 있습니다. 하위 구성요소 555를 새로 삽입하고 다른 구성요소의 위치를 ​​변경했습니다.

3. 키를 올바르게 선택하세요

3.1 순수 표시

구성 요소가 순수하게 표시에만 사용되고 다른 변경 사항이 발생하지 않으면 인덱스나 다른 값을 키로 사용해도 문제가 없습니다. diff가 발생하지 않으면 키가 사용되지 않습니다.

3.2 index 사용을 권장하는 상황

다음과 같은 경우 index를 키로 사용해도 아무런 단점이 없습니다.

목록을 페이지 단위로 렌더링하려고 하는데 매번 다시 렌더링됩니다. 페이지를 넘기려면 클릭하세요.

고유 ID 사용:

第一页
<ul>
    <li key="000">张三</li>
    <li key="111">李四</li>
    <li key="222">王五</li>
</ul>
第二页
<ul>
    <li key="333">张三三</li>
    <li key="444">李四四</li>
    <li key="555">王五五</li>
</ul>
로그인 후 복사

페이지를 넘긴 후 세 레코드의 키와 구성 요소가 변경되었으므로 세 하위 구성 요소가 언로드되고 다시 렌더링됩니다.

사용 인덱스:

第一页
<ul>
    <li key="0">张三</li>
    <li key="1">李四</li>
    <li key="2">王五</li>
</ul>
第二页
<ul>
    <li key="0">张三三</li>
    <li key="1">李四四</li>
    <li key="2">王五五</li>
</ul>
로그인 후 복사

페이지를 넘긴 후에도 키는 변경되지 않고 하위 구성 요소의 값이 변경되며 구성 요소는 제거되지 않고 업데이트만 됩니다.

3.3 하위 구성 요소가 제어되지 않는 구성 요소를 변경/사용했을 수 있습니다

대부분의 경우 고유 ID를 하위 구성 요소의 키로 사용하는 데 문제가 없습니다.

이 ID는 고유하고 안정적이어야 합니다. 즉, 이 레코드에 해당하는 ID는 고유해야 하며 절대 변경되지 않습니다.

고유한 값을 키로 생성하기 위해 math.random 또는 기타 타사 라이브러리를 사용하는 것은 권장되지 않습니다.

데이터가 변경되면 동일한 데이터의 키도 변경되어 다시 렌더링되어 불필요한 성능 낭비가 발생할 수 있기 때문입니다.

데이터 소스가 요구 사항을 충족하지 않는 경우 렌더링할 때 추가하는 대신 렌더링하기 전에 데이터 소스에 고유 ID를 수동으로 추가할 수 있습니다.

위 내용은 반응에서 키의 구체적인 사용 소개(코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿