zoukankan      html  css  js  c++  java
  • Vue.js 源码学习笔记 -- 分析前准备2 -- Object.defineProperty

    解析神奇的 Object.defineProperty

      几行代码看他怎么用

     

      

    var a= {}
    
    Object.defineProperty(
      a,
      "b",
      {
        value:123
      });
    
    console.log(a.b); //123

    很简单,它接受三个参数,而且都是必填的

    等价于

     

      

    var a= {}
    Object.defineProperty(a,"b",{ value:123, writable:false, enumerable:false, configurable:false // 这个为false, 再对a, 其他的任何设置都会报错 })

    a.value = 1; //error
    console.log(a.b);//123
    var a = {}; 
    
    Object.defineProperty(o, "b", { 
        value : 123,
        writable : false });
    
    console.log(a.b); // 打印 37
    a.b = 25; // 没有错误抛出(在严格模式下会抛出,即使之前已经有相同的值)
    console.log(o.a); // 打印 37, 赋值不起作用。
    

      

    var a= {}
    Object.defineProperty(a,"b",{
      value:3445,
      enumerable:false //注意咯这里改了
    })
    console.log(Object.keys(a));// 打印[]  for in也不行
    

      

    在 descriptor 中不能同时设置访问器(get 和 set)和 wriable 或 value,否则会错,就是说想用 get 和 set,就不能用 writable 或 value 中的任何一个。

    var a= {}
    Object.defineProperty(a,"b",{
      set:function(newValue){
        console.log("我检查检测到你赋值给我了,我的新值是"+newValue)
        },
      get:function(){
        console.log("我检测到你取我的值")
        return 2 //注意这里,我硬编码返回2
       }
    })
    a.b =1 //打印 你要赋值给我,我的新值是1
    console.log(a.b)    //打印 你取我的值
                        //打印 2    注意这里,和我的硬编码相同的
    

      

    简单来说,这个 “b” 赋值或者取值的时候会分别触发 set 和 get 对应的函数

    这就是实现 observe的关键啊。

  • 相关阅读:
    Asp.net MVC 利用 Nopi 导出 Excel
    React 中 调用 Asp.net WebApi
    Node.js mysql 连接池使用事务自动回收连接
    __far和__near的小问题
    注册博客园了,以后在这里写写随笔。
    Electron客户端开发入门必备的知识点
    公司组织构架的三大类型
    经济学中的人性抉择(下)
    经济学中的人性抉择(上)
    模拟音乐播放器播放条样式
  • 原文地址:https://www.cnblogs.com/dhsz/p/6393575.html
Copyright © 2011-2022 走看看