
在react应用开发中,当我们在组件中渲染一个列表(例如使用map方法遍历数组生成一组jsx元素)时,控制台经常会看到一个警告:“warning: each child in a list should have a unique "key" prop.”。这个警告提示我们,列表中的每个子元素都应该有一个唯一的key属性。
考虑以下一个常见的骨架屏(Shimmer)组件示例,它旨在渲染一组占位符卡片:
const Shimmer = () => {
return (
<div className="restraunt-list" >
{Array(15)
.fill("")
.map((e) => (
<div className="shimmer-card"> </div>
))}
</div>
);
};
export default Shimmer;这段代码尝试渲染15个shimmer-card占位符,但由于没有为每个div元素提供key属性,React会在运行时发出上述警告。
key属性在React的协调(Reconciliation)算法中扮演着至关重要的角色。当列表中的元素顺序发生变化、元素被添加或删除时,React需要一种高效的方式来识别哪些DOM元素需要被更新、移动、删除或创建。key属性就是React用来区分列表中每个元素的唯一标识符。
具体来说,key的作用体现在以下几个方面:
解决“Each child in a list should have a unique 'key' prop”警告的方法很简单:为map方法中返回的每个JSX元素添加一个唯一的key属性。
对于上述的Shimmer组件场景,由于我们只是渲染一个固定数量的、内容相同的占位符,并且这些占位符的顺序不会改变,使用数组的index作为key是一个简单且有效的解决方案:
const Shimmer = () => {
return (
<div className="restraunt-list">
{Array(20) // 假设渲染20个占位符
.fill("")
.map((e, index) => ( // 使用map的第二个参数index
<div key={index} className="shimmer-card"> {/* 将index作为key */}
<img className="shimmer-image" alt="Shimmer placeholder" />
<p className="shimmer-card-heading"></p>
<p className="shimmer-card-restaurant-name"></p>
</div>
))}
</div>
);
};
export default Shimmer;在这个修改后的代码中,我们为每个shimmer-card``div元素添加了key={index}。这样,React就能为每个占位符分配一个从0开始的唯一标识符,从而消除警告。
虽然在Shimmer组件这种静态、内容无状态且顺序固定的列表场景下,使用index作为key是可接受的,但在大多数实际应用中,这种做法并不推荐。
何时不应使用index作为key:
当列表满足以下任一条件时,不应使用index作为key:
最佳实践:使用稳定且唯一的ID作为key
最理想的key是数据项本身自带的、在整个应用生命周期中稳定且唯一的ID。这通常是后端数据库返回的唯一标识符。
例如,如果你的列表数据是来自API的餐馆列表:
const restaurants = [
{ id: 'r101', name: '美味餐厅', rating: 4.5 },
{ id: 'r102', name: '小吃街', rating: 4.0 },
// ...
];那么,正确的做法应该是使用restaurant.id作为key:
const RestaurantList = ({ restaurants }) => {
return (
<div className="restaurant-list">
{restaurants.map((restaurant) => (
<RestaurantCard key={restaurant.id} restaurant={restaurant} />
))}
</div>
);
};当没有稳定ID时:
如果你的数据没有现成的唯一ID,你可以考虑以下方案:
key属性是React高效渲染列表的关键。在创建动态列表时,务必为每个列表子元素提供一个稳定且唯一的key。虽然在像骨架屏这样静态且无状态的场景下可以使用index作为key,但对于大多数涉及数据动态变化的列表,强烈建议使用数据本身的唯一ID。理解并正确应用key属性,将有助于我们构建性能更优、行为更稳定的React应用。
以上就是深入理解React列表中“key”属性的重要性与最佳实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号