列表 & key
渲染多个组件
function NumberList(props) {
const numbers = props.numbers;
const listItems = numbers.map((number) =>
//不写key会看到警告 a key should be provided for list items
<li key={number.toString()}>
{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')
);
个人笔记专用

浙公网安备 33010602011771号