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

相关推荐
我命由我123456 小时前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js
E***q5396 小时前
Vue增强现实开发
前端·vue.js·ar
S***42806 小时前
JavaScript在Web中的Angular
前端·javascript·angular.js
4***14906 小时前
Vue代码规范详解
javascript·vue.js·代码规范
黑幕困兽6 小时前
ehcarts 实现 饼图扇区间隙+透明外描边
前端·echarts
San306 小时前
深入理解 JavaScript 词法作用域链:从代码到底层实现机制
前端·javascript·ecmascript 6
进击的野人6 小时前
深入理解 JavaScript Promise:原理、用法与实践
javascript·面试·ecmascript 6
七淮6 小时前
Next.js SEO 优化完整方案
前端·next.js
e***19356 小时前
爬虫学习 01 Web Scraper的使用
前端·爬虫·学习
我有一棵树6 小时前
file 协议与 http 协议的区别:为什么本地 HTML 无法加载相对路径 JS,以及正确的解决方式
javascript·http·html