其他分享
首页 > 其他分享> > 列表 & key

列表 & key

作者:互联网

 渲染多个组件

function NumberList(props) {

  const numbers = props.numbers;
  const listItems = numbers.map((number) =>
    <li key={number.toString()}>       //不写key会看到警告 a key should be provided for list items
    {number} </li> ); return ( <ul>{listItems}</ul> ); } const numbers = [1, 2, 3, 4, 5]; ReactDOM.render( <NumberList numbers={numbers} />, document.getElementById('root') );

key
  key帮助React识别哪些元素被改变了 比如被添加或删除
因此给数组中的元素赋予一个确定的标识
const numbers = [1, 2, 3, 4, 5];
const listItems = numbers.map((number) =>
  <li key={number.toString()}>    {number}
  </li>
);

通常使用数据中的id作为元素的key
const todoItems = todos.map((todo) =>
  <li key={todo.id}>    {todo.text}
  </li>
);
当元素没有确定id,可以使用元素的索引index作为key
const todoItems = todos.map((todo, index) =>
  // Only do this if items have no stable IDs  <li key={index}>    {todo.text}
  </li>
);
如果列表项目的顺序可能会变化,我们不建议使用索引来用作 key 值,因为这样做会导致性能变差,
还可能引起组件状态的问题。如果你选择不指定显式的 key 值,那么 React 将默认使用索引用作为列表项目的 key 值。

用key提取组件
function ListItem(props) {
  // 正确!这里不需要指定 key:  return <li>{props.value}</li>;}

function NumberList(props) {
  const numbers = props.numbers;
  const listItems = numbers.map((number) =>
    // 正确!key 应该在数组的上下文中被指定    <ListItem key={number.toString()} value={number} />  );
  return (
    <ul>
      {listItems}
    </ul>
  );
}

const numbers = [1, 2, 3, 4, 5];
ReactDOM.render(
  <NumberList numbers={numbers} />,
  document.getElementById('root')
);
 

 

标签:const,listItems,列表,numbers,key,props,number
来源: https://www.cnblogs.com/bingyangyang/p/14144366.html