【八股系列】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

相关推荐
baobao17676408307 分钟前
C++单例模式
javascript·c++·单例模式
好_快25 分钟前
Lodash源码阅读-isFlattenable
前端·javascript·源码阅读
excel25 分钟前
webpack 格式化模块 第 六 节
前端
excel27 分钟前
webpack 格式化模块 第 五 节
前端
好_快28 分钟前
Lodash源码阅读-concat
前端·javascript·源码阅读
好_快29 分钟前
Lodash源码阅读-baseFlatten
前端·javascript·源码阅读
勘察加熊人31 分钟前
vue+d3js+fastapi实现天气柱状图折线图饼图
前端·vue.js·fastapi
好_快33 分钟前
Lodash源码阅读-chunk
前端·javascript·源码阅读
智绘前端1 小时前
Vue3的Composition API与React Hooks有什么异同?
前端·vue.js·react.js·前端框架·vue