前端100问:

博客围绕在React/Vue项目列表组件中写key的原因及作用展开。介绍了数据变化时vue更新节点的方式,借助diff算法,先根据真实DOM生成virtual DOM,对比新旧Vnode后修改真实DOM。还提及了virtual DOM和真实DOM的区别,前者以对象模拟树形结构。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第 1 题:(滴滴、饿了么)写 React / Vue 项目时为什么要在列表组件中写 key,其作用是什么?

理解几个概念:
(1)当数据发生变化时,vue是怎么更新节点的?
改了某个数据,如果直接渲染到真实dom上会引起整个dom树的重绘和重排。
diff算法能够帮助我们,先根据真实DOM生成一颗virtual DOM,当virtual DOM某个节点的数据改变后会生成一个新的Vnode,然后Vnode和oldVnode作对比,发现有不一样的地方就直接修改在真实的DOM上,然后使oldVnode的值为Vnode。
diff的过程就是调用名为patch的函数,比较新旧节点,一边比较一边给真实的DOM打补丁。
(2).virtual DOM和真实DOM的区别?
virtual DOM是将真实的DOM的数据抽取出来,以对象的形式模拟树形结构。比如dom是这样的:

<div>
    <p>123</p>
</div>

对应的virtual DOM(伪代码):

 var Vnode = {
        tag: 'div',
        children: [
            { tag: 'p', text: '123' }
        ]
    };
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值