react和vue更新机制的差异

react是通过setState() 驱动数据 当前节点更新整个state 运用的技术是immutable 技术这immutable 翻译过来就是不可变的 ,就是说state的数据是不可变,如果要改变,就要通过重新生成一个不可变的数据来替换state(注意 :是整个节点树,自顶而下的更新) 如果要避免不必要的更新 需要增加shouldComponentUpdate 这个周期函数里判断是否要更新 return false 就是不更新 组件式函数用的是useMemo

vue的更新原来是通过数据劫持来驱动更新,在create的时候,把data里面所有的属性都通过Object.defineproperty增加getter和setter属性,在setter的时候 通过notify() 通知遍历更新(实例会缓存全局Watcher)。

和react相比 vue的数据是立即就能变化的,而在react里数据都是不变的 这也就是为什么react里 setState 后 立即console.log(state) 还是原先的state

相同:都是异步更新 都是用diff算法更新dom

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值