数据代理Object.defineProperty()

数据代理: 通过一个对象代理对另一个对象中属性的操作(读/写)

数据代理

Object.defineProperty()

Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回此对象。

Object.defineProperty(obj, prop, desc)
  • obj 需要定义属性的当前对象
  • prop 当前需要定义的属性名
  • desc 属性描述符

属性描述符

数据描述符

  • configurable:是否可以重新定义

  • enumerable:是否可以枚举

  • value:初始值

  • writable:是否可以修改属性值

访问描述符

  • get:是一个回调函数,根据其他相关的属性动态计算得到当前属性值
  • set:也是一个回调函数,监视当前属性值的变化,更新其他相关的属性值
<script type="text/javascript" >
    let number = 18
    let person = {
        name:'张三',
        sex:'男',
    }

    Object.defineProperty(person,'age',{
        // value:18,
        // enumerable:true, //控制属性是否可以遍历,默认值是false
        // writable:true, //控制属性是否可以被修改,默认值是false
        // configurable:true //控制属性是否可以被删除,默认值是false

        //当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age的值
        get(){
            console.log('有人读取age属性了')
            return number
        },

        //当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值
        set(value){
            console.log('有人修改了age属性,且值是',value)
            number = value
        }

    })

			// console.log(Object.keys(person))

</script>

VUE中的数据代理

Vue中的数据代理:通过实例对象vm来代理data对象中属性的操作(读/写)
基本原理:

  • 通过Object.defineProperty()把data对象中所有属性添加到vm上。
  • 为每一个添加到vm上的属性,都指定一个getter/setter。
  • 在getter/setter内部去操作(读/写)data中对应的属性。
//通过一个对象代理对另一个对象中属性的操作(读/写)-->
let obj = {x:100}
let obj2 = {y:200}

Object.defineProperty(obj2,'x',{
    get(){
        return obj.x
    },
    set(value){
        obj.x = value
    }
})
posted @ 2021-08-03 16:07  至安  阅读(101)  评论(0编辑  收藏  举报