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

相关推荐
馬致远3 分钟前
Vue 脚手架&环境配置
前端·javascript·vue.js
IT_陈寒4 分钟前
React性能优化实战:5个被低估的Hooks技巧让你的应用提速30%
前端·人工智能·后端
SDAU20055 分钟前
ESP32C3在Arduino下的MQTT操作
linux·服务器·前端
syt_10135 分钟前
grid布局之-子项放置1
前端·javascript·css
一字白首6 分钟前
Vue 项目实战,从组件缓存到 Vant UI 集成:项目初始化全流程
vue.js·ui·缓存
HIT_Weston7 分钟前
59、【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(三)
前端·ubuntu·gitlab
syt_10137 分钟前
grid布局之-子项放置2
前端·javascript·css
韩曙亮7 分钟前
【Web APIs】JavaScript 动画 ② ( 缓动动画 | 步长计算取整 )
前端·javascript·动画·web apis·缓动动画·匀速动画
fruge9 分钟前
Vue3 响应式原理深度解析:Proxy 实现与依赖收集逻辑
前端
by__csdn10 分钟前
javascript 性能优化实战:异步和延迟加载
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript