为了账号安全,请及时绑定邮箱和手机立即绑定

Vue和React数据绑定对比

标签:
React.JS Vue.js

在数据绑定上来说,vue的特色是双向数据绑定,而在react中是单向数据绑定。

一 单向和双向数据绑定其实不是完全没关系的

表单的双向绑定,说到底不过是 (value 的单向绑定 + onChange 事件侦听)的一个语法糖,你如果不想用 v-model,像 React 那样处理也是完全可以的。另一方面,组件间的数据传递,Vue 默认是单向的,和 React 一样。

上面这段话是尤雨溪在回答Vue和React的使用场景和深度有何不同?这个问题中提到的。既然数据从V(view)->M(model)的绑定都是通过事件监听实现,那我们主要把重点放在对数据从M->V的绑定。


二 Vue和React中数据绑定原理

在 React 应用中,当某个组件的状态发生变化时,它会以该组件为根,重新渲染整个组件子树。当然,这可以通过shouldComponentUpdate这个生命周期方法来进行控制purerender,但Vue将此视为默认的优化。

vue中实现数据绑定靠的是数据劫持(Object.defineProperty())+发布-订阅模式。在 Vue 应用中,组件的依赖是在渲染过程中自动追踪的,所以系统能精确知晓哪个组件需要被重渲染。你可以理解为每一个组件都已经自动获得了shouldComponentUpdate,并且没有上述的子树问题限制。Vue对比其他框架

我们来看看视图更新的流程
react:

webp

react-update.png


React组件性高效渲染


vue:


webp

vue-update.png

这里我们要注意的是watcher是来决定你要不要更新这个组件吧,而虚拟DOM是用来找出怎么以最小的代价来更新这个dom。两者并没有重复解的意味。


三 Vue和React中实现数据双向绑定

vue中

<input  v-model="userName" /><input v-bind:value="userName" v-on:input="userName = $event.target.value" />

第一行的代码其实只是第二行的语法糖。input 元素本身有个 oninput事件,这是 HTML5 新增加的,类似 onchange ,每当输入框内容发生变化,就会触发 oninput

react中


webp

react-rebind.png

参考:
react和vue官网



作者:pattyzzh
链接:https://www.jianshu.com/p/6e124ad23c68


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消