vue计算属性的原理

之前一直很喜欢计算属性,现在找了相关文档,整理了一份关于计算属性的原理文章
计算属性是一个很邪门的东西,只要在它的函数里引用了 data 中的某个属性,当这个属性发生变化时,函数仿佛可以嗅探到这个变化,并自动重新执行。



上述代码会源源不断的打印出 b 的值。如果希望 a 依赖 data 中的 x 而变化,只需保证 a 函数中有 this.x 即可。如果函数中没有出现 data 中的属性,那么无论 data 中的属性怎么变,a 对应的函数一次也不会执行。

  Vue 怎么知道计算属性在函数中引用了哪个 data 属性?这个函数又是怎么知道 data 属性变了,而且只关心它内部引用的那个属性,别的都不管?

我们简单模拟实现一个计算属性:a 变化时,b 自动跟着变化。


由于涉及 Vue 的响应式绑定的原理,如果你对此不熟,最好先看看《Vue.js 双向绑定的实现原理》

  1\. 首先 b 属性会被处理为存取器属性,访问 b 就会触发其 get 函数

  2\. 处理计算属性 a 时,会执行 a 的函数,从而会执行 this.b,于是触发 b 的 get 函数

  3\. b 的 get 函数会添加 b 属性的依赖项,而刚才在处理计算属性过程中,a 已经作为依赖项被传给了一个全局变量,b 的 get 函数会检测到这个全局变量,并将其添加到自身的订阅者列表中

  4\. 对 b 赋予新的值时,会触发其 set 函数,set 函数中会遍历执行订阅者,a 的值就是在这个时候更新的

  再看代码:
 测试一下,完美打印出 1, 2, 3, 4

  console.log(obj.b)

  obj.a += 1;

  console.log(obj.b);

  obj.a += 1;

  console.log(obj.b);

  obj.a += 1;

  console.log(obj.b);

  通过对存取器属性、闭包和观察者模式的综合运用,Vue 巧妙的实现了计算属性。现在再看官方文档描述,是不是更通透了呢。

  可以看出,Vue 响应式系统的核心理念是“依赖”,DOM 节点之所以随数据而变化,是因为节点依赖于数据,计算属性之所以随数据而变化,是因为计算属性依赖于数据。做好响应式的关键就在于处理好依赖关系。
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 9,049评论 0 13
  • 在看了一期《向往的生活》后 发现倪妮和井柏然分手了 而这期,刚好是倪妮去的那一期 其实,他们分手的消息大家早就猜到...
    哈哈哒_766c阅读 181评论 0 0
  • 1、阅读了老师的《你的写作属于纯自嗨吗?》一文,文章中“四有文章”我对有趣最有共鸣。打小我的语文老师说我的阅读理解...
    隙间白狗阅读 211评论 6 2
  • 先生昨天微信我,说是朋友约了今天去开沙岛摘西瓜。我一想到大热天的在瓜地里溜哒,心中一百个不乐意。恰巧昨晚妹妹跟侄女...
    如眉新月阅读 327评论 0 0
  • 张爱玲说,喜欢一个人,会卑微到尘埃里,然后开出花来。 我喜欢过一个人,没有卑微到尘埃里,并没有开出花,它长成了一棵...
    YueyueSW阅读 381评论 0 0