受现代 Javascript 的限制(以及废弃 Object.observe),Vue 不能检测到对象属性的添加或删除。

原文

vue文档深入响应式原理一章关于变化检测问题中的这句话什么意思,具体是js的什么限制?

阅读 3.8k
1 个回答

ECMAScript中有两种属性:数据属性和访问器属性;
数据属性的描述符为:Configurable,Enumerable,Writable,Value;
访问器属性的描述符为:Configurable, Enumerable,set,get。

当我们使用new Vue(obj),其内部发生了大体如下代码的转换,即将数据属性,转换为了访问器属性

function Vue(obj){
    obj.data.keys().forEach((prop, index) => {
      Object.defineProperty(obj.data, prop, {
        set(){
          //可以在此处进行事件监听
        },
        get(){
    
        }
      })
    })
    return obj;
 }

但是当我们后面再次使用普通的赋值,仅仅是赋值了一个数据属性的,这个属性是不会具有访问器属性的事件监听功能的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题