【八股系列】vue的双向绑定原理是什么?

Vue 的双向绑定是通过数据劫持发布-订阅模式实现的。
Vue中,每一个组件都有一个对应的Watcher实例,它会观察组件中所有需要被双向绑定 的属性。当属性的值发生变化 时,Watcher会通知相应的Dep对象,Dep对象会通知所有订阅 它的Watcher实例,然后触发组件的重新渲染
在组件的模板中,Vue会将需要被双向绑定的属性和组件的data属性建立起一个响应式的关系。当用户在模板中修改了属性的值 时,Vue触发 相应的setter函数,setter函数会通知Dep对象,Dep对象会通知所有订阅它的Watcher实例,然后触发组件的重新渲染。

下面的流程图可以帮助理解Vue的双向绑定原理:
data Observer Dep Watcher Component Render Template User Input Setter Dep Watcher Component Render

相关推荐
sen_shan8 分钟前
《Vue项目开发实战》第八章:组件封装--vxeGrid
前端·javascript·vue.js
五点六六六9 分钟前
双非同学校招笔记——离开字节入职小📕
前端·面试·程序员
IT_陈寒10 分钟前
Redis实战:5个高频应用场景下的性能优化技巧,让你的QPS提升50%
前端·人工智能·后端
2***574211 分钟前
Vue项目国际化实践
前端·javascript·vue.js
我也爱吃馄饨12 分钟前
写的webpack插件如何适配CommonJs项目和EsModule项目
java·前端·webpack
全马必破三12 分钟前
HTML常考知识点
前端·html
3秒一个大23 分钟前
JavaScript 作用域:从执行机制到块级作用域的演进
javascript
OLong26 分钟前
忘掉"发请求",声明你要的数据:TanStack Query 带来的思维革命
前端
琦遇27 分钟前
Vue3使用vuedraggable实现拖拽排序
前端
银月流苏28 分钟前
Vue 深度选择器 `:deep` 使用说明
前端