为什么react列表要加key

为什么列表要加 key 属性,以及为什么用 index 是不好的

遍历对象的每一个属性深度对比是非常浪费性能的

React 使用列表的key来进行对比,如果不指定,就默认为 index 下标

那么,为什么 不指定 key/用 index 下标 是不好的呢?

假设现在有这样一段代码:

const users = [{ username: "bob" }, { username: "sue" }];

users.map((u, i) => <div key={i}>{u.username}</div>);

它会渲染出这个 DOM 树:

<div key="1">bob</div>
<div key="2">sue</div>

然后用户做了某个操作,usersunshift 另一个对象,变成:

const users = [
  { username: "new-guy" },
  { username: "bob" },
  { username: "sue" },
];

DOM 树就会变成这样,注意key的变化:

<div key="1">new-guy</div>
<div key="2">bob</div>
<div key="3">sue</div>

DOM 树的前后对比是这样的:

<div key="1">bob</div>   |  <div key="1">new-guy</div>
<div key="2">sue</div>   |  <div key="2">bob</div>
                         |  <div key="3">sue</div>

我们人类看得出来前后的变化只是在开头加了一个new-guy而已

但是由于 React 使用 key 值来识别变化,所以 React 认为的变化是:

  1. bob -> new-guy
  2. sue -> bob
  3. 添加 sue

非常消耗性能 😭

但是如果我们一开始就给它指定一个合适的 key,比如用 name:

users.map((u, i) => <div key={u.username}>{u.username}</div>);

React 认为的变化就变成:

                         |  <div key="1">new-guy</div>
<div key="1">bob</div>   |  <div key="2">bob</div>
<div key="2">sue</div>   |  <div key="3">sue</div>

这样只需要做一个unshift操作,性能节省 😃

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值