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

相关推荐
喧星Aries9 分钟前
进程调度的时机,切换与过程方式(操作系统OS)
java·服务器·前端·操作系统·进程调度
海底火旺11 分钟前
useState:批处理与函数式更新
前端·react.js·面试
一块plus12 分钟前
一门原本只是“试试水”的课程,没想到炸出了一群真诚的开发者
javascript·面试·github
亿万托福13 分钟前
数字世界的构筑之艺:前端技术栈的浅描与远瞻
前端
用户408128120038114 分钟前
JWT 和 token 区别
前端
yvvvy14 分钟前
🚀React + Vite 实战:打造智能单词学习应用
javascript
盏茶作酒2915 分钟前
打造自己的组件库(三)打包及发布
前端·vue.js
单休好_好就好在比双休少一天15 分钟前
Vite打包从12.17M -> 7.95M,速度提升≈51.85%
前端·javascript
yinke小琪15 分钟前
JavaScript DOM内容操作常用方法和XSS注入攻击
前端·javascript
归于尽16 分钟前
从 TodoList 看自定义 Hook 的设计思想
前端