React 列表
在 React 中,您将使用某种循环来渲染列表。
JavaScript 的 map()
数组方法通常是首选方法。
如果您需要复习 map()
方法,请查看 ES6 部分。
示例
让我们渲染车库里的所有汽车
function Car(props) {
return <li>I am a { props.brand }</li>;
}
function Garage() {
const cars = ['Ford', 'BMW', 'Audi'];
return (
<>
<h1>Who lives in my garage?</h1>
<ul>
{cars.map((car) => <Car brand={car} />)}
</ul>
</>
);
}
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Garage />);
当您在 create-react-app
中运行此代码时,它将起作用,但您会收到一条警告,即列表项未提供“key”。
Keys
Keys 允许 React 跟踪元素。这样,如果一个项目被更新或删除,只有该项目会被重新渲染,而不是整个列表。
Keys 需要是每个同级元素的唯一标识。但它们可以在全局范围内重复。
通常,key 应该是分配给每个项目的唯一 ID。作为最后的手段,您可以使用数组索引作为 key。
示例
让我们重构之前的示例,以包含 key
function Car(props) {
return <li>I am a { props.brand }</li>;
}
function Garage() {
const cars = [
{id: 1, brand: 'Ford'},
{id: 2, brand: 'BMW'},
{id: 3, brand: 'Audi'}
];
return (
<>
<h1>Who lives in my garage?</h1>
<ul>
{cars.map((car) => <Car key={car.id} brand={car.brand} />)}
</ul>
</>
);
}
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Garage />);