Vue数据监听

参考文章:
https://www.jb51.net/article/124439.htm
http://www.php.cn/js-tutorial-393678.html
https://www.jianshu.com/p/1032ecd62b3a
https://www.cnblogs.com/leaf930814/p/9014200.html
http://www.php.cn/js-tutorial-393678.html
https://blog.csdn.net/it_rod/article/details/79516578

通过源码分析Vue的双向数据绑定详解

Vue源码的整体架构无非是初始化Vue对象,挂载数据data/props等,在不同的时期触发不同的事件钩子,如created() / mounted() / update()等,后面专门整理各个模块的文章。这里先讲双向数据绑定的部分,也是最主要的部分。
设计思想:观察者模式
Vue的双向数据绑定的设计思想为观察者模式,为了方便,下文中将被观察的对象称为观察者,将观察者对象触发更新的称为订阅者。主要涉及到的概念有:
1、Dep对象:Dependency依赖的简写,包含有三个主要属性id, subs, target和四个主要函数addSub, removeSub, depend, notify,是观察者的依赖集合,负责在数据发生改变时,使用notify()触发保存在subs下的订阅列表,依次更新数据和DOM。
id: 每个观察者(依赖对象)的唯一标识。
subs: 观察者对象的订阅者列表。
target: 全局唯一的订阅者对象,因为只能同时计算和更新一个订阅者的值。
addSub(): 使用push()方法添加一个订阅者。
removeSub(): 使用splice()方法移除一个订阅者。
depend(): 将自己添加到当前订阅者对象的依赖列表。
notify(): 在数据被更新时,会遍历subs对象,触发每一个订阅者的更新。
2、Observer对象:即观察者,包含两个主要属性value, dep。做法是使用getter/setter方法覆盖默认的取值和赋值操作,将对象封装为响应式对象,每一次调用时更新依赖列表,更新值时触发订阅者。绑定在对象的__ob__原型链属性上。
value: 原始值。
dep: 依赖列表。
源码实战解析
有过Vue开发基础的应该都了解其怎么初始化一个Vue对象:

new Vue({
   
 el: '#container',
 data: {
   
  count: 100
 },
 ...
});

那么我们就从这个count说起,看它是怎么完成双向数据绑定的。
下面的代码片段中英文注释为尤雨溪所写,中文注释为我所写,英文注释更能代表开发者的清晰思路。
首先从全局的初始化函数调用:initMixin(Vue$3); ,这里的Vue$3对象就是全局的Vue对象,在此之前已经挂载了Vue的各种基本数据和函数。这个函数体就是初始化我们上面声明Vue语句的过程化逻辑,取主体代码来看:

// 这里的options就是上面声明Vue对象的json对象
Vue.prototype._init = function (options) {
   
 ...
 var vm = this;
 ...
 initLifecycle(vm);
 initEvents(vm);
 initRender(vm);
 callHook(vm, 'beforeCreate');
 // 这里就是我们接下来要跟进的初始化Vue参数
 initState(vm);
 initInjections(vm);
 callHook(vm, 'created');
 ...
 };

这里主要完成了初始化事件、渲染、参数、注入等过程,并不断调用事件钩子的回调函数。下面来到如何初始化参数:

function initState (vm) {
   
 vm._watchers = [];
 var opts = vm.$options;
 if (opts.props) {
    initProps(vm, opts.props); }
 if (opts.methods) {
    initMethods(vm, opts.methods); }
 // 我们的count在这里初始化
 if (opts.data) {
   
 initData(vm);
 } else {
   
 observe(vm._data = {
   }, true /* asRootData */);
 }
 if (opts.computed) {
    initComputed(vm, opts.computed); }
 if (opts.watch) {
    initWatch(vm, opts.watch); }
}

这里依次检测参数中包含的props/methods/data/computed/watch并进入不同的函数进行初始化,这里我们只关心initData:

function initData (vm) {
   
 var data = vm.$options.data;
 data = vm._data = typeof data === 'function'
 ? data.call(vm)
 : data 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 监听Vue数据是指通过Vue提供的监听方法,可以实时监测到数据的变化并做出相应的操作。在Vue中,我们可以使用watch来监听数据的变化。 通过在Vue实例中使用watch属性,我们可以将要监听数据以字符串形式传递给watch,并在watch中定义一个函数,当数据发生变化时,该函数就会被触发。 例如,假设我们要监听一个叫做"count"的数据,可以在Vue实例中添加如下代码: ``` watch: { count(newValue, oldValue) { console.log('count的值发生变化啦!新的值为:' + newValue + ',旧的值为:' + oldValue); // 可以在这里执行一些自定义的操作 } } ``` 在上述代码中,我们在watch属性中定义了一个count函数,当count数据发生变化时,该函数会被触发。在函数体中,我们可以获取到变化后的新值和变化前的旧值,并可以在这里执行一些自定义的操作。 监听Vue数据可以帮助我们实时获取数据的变化情况,以便及时做出响应。这对于一些需要实时更新数据的场景非常有用,比如当数据发生变化时,我们需要根据新的数据进行计算、展示等操作。 总之,通过监听Vue数据,我们可以在数据变化时得到通知,并进行相应的处理,从而实现数据的实时更新及操作。 ### 回答2: Vue是一种用于构建用户界面的渐进式JavaScript框架。它通过数据驱动和组件化的方式使得开发者可以简单、高效地构建可复用的UI组件。Vue数据监听机制是其核心特性之一。 Vue通过采用响应式的数据绑定机制来监听数据的变化。当一个数据被绑定到Vue实例中的属性时,Vue会将这个属性转化为getter/setter,并且在需要的时候收集依赖和触发更新。这个机制可以让Vue追踪到每个属性的依赖关系,并在属性发生变化时自动更新有关联的组件。 Vue实现数据监听的方式主要有两种:Object.defineProperty和Proxy。在较低版本的浏览器中,Vue使用Object.defineProperty来实现数据监听。它通过重写对象属性的getter和setter来实现依赖追踪和更新通知。在较新版本的浏览器中,Vue使用Proxy来实现数据监听。Proxy可以劫持整个对象,不需要像Object.defineProperty那样重写getter和setter。 对于Vue来说,数据监听是非常重要的,它可以让开发者编写的代码更具有可维护性和可复用性。当数据发生变化时,Vue会自动检测到这些变化并更新相关的组件,从而实现了数据和视图的双向绑定。这种自动化的数据监听机制可以极大地减少开发者的工作量,提高开发效率。 以一个简单示例来说明数据监听的实现方式。假设有一个Vue实例: ```javascript var vm = new Vue({ data: { message: 'Hello Vue!' } }) ``` 当我们修改`data`中的`message`属性时,例如: ```javascript vm.message = 'Hello World!' ``` Vue会自动检测到`message`属性的变化,并更新对应的组件。在这个示例中,Vue会将`message`属性转化为getter/setter,并在需要的时候触发组件的更新操作,使得界面中显示的内容变为新的值。 综上所述,Vue数据监听机制是通过响应式的数据绑定方式来实现的,它是Vue框架的核心特性之一,能够实现数据和视图的自动更新,提高开发效率和减少工作量。 ### 回答3: Vue 是一种用于构建用户界面的渐进式JavaScript框架。它包含了一系列的工具和库,使开发人员能够轻松地构建复杂的单页应用程序。Vue 提供了一种数据监听的机制,可以实时地追踪和更新数据的变化。 Vue数据监听是通过Vue实例中的数据属性来实现的。当数据发生变化时,Vue会自动检测到变化并更新相应的视图。这种监听机制可以确保视图与数据的同步,使开发者能够更加便捷地操作数据和界面。 Vue提供了多种监听数据变化的方式。最常见的方式是使用`v-model`指令将数据绑定到表单元素上,当表单数据发生变化时,Vue会自动更新与之绑定的数据属性。此外,Vue还提供了`watch`属性,可以监听指定数据的变化并执行相应的回调函数。通过`computed`属性,Vue还可以创建计算属性,实时计算数据依赖关系。 除了上述常用方式外,Vue还提供了更高级的数据监听功能。开发者可以使用`$watch`方法手动监听数据的变化。使用该方法,可以监听具体的属性变化,也可以监听整个数据对象的变化。这种方式可以更加灵活地对数据进行监听和操作。 总而言之,Vue提供了灵活而强大的数据监听功能,使开发者能够方便地追踪和处理数据的变化。这为开发人员提供了更好的开发体验和更快速的应用程序开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值