一、Object.defineProperty:给一个对象定义一个新的属性或修改一个对象现有的属性,并且返回这个对象

1.语法:Object.defineProperty(参数1,参数2,参数3)

  参数1:目标对象

  参数2:需要修改或者添加的属性名

  参数3:目标对象属性的一些特征(是一个对象)

  其中参数3中也有一些参数:

    参数1:value:属性值

    参数2:writable:对象属性值是否可被修改,true表示允许,false表示不允许

    参数3:configurable:对象属性是否可被删除,true为允许,false为不允许

    参数4:enumerable:对象属性是否可被枚举(即遍历)

    参数5:get():给一个属性提供getter方法,当访问这个对象的属性值时触发该方法

    参数6:set():给一个属性提供setter方法,当设置这个对象的属性值时触发该方法

二、参数示例

1、value

  var obj = {};
  Object.defineProperty(obj,"name",{value:"Leslie Cheung"});
  Object.defineProperty(obj,"age",{value:22});
  console.log(obj);//Object(是一个Object对象)

2、writable

    var obj = {};
Object.defineProperty(obj,"name",{
value:"Leslie Cheung",
writable:false//为false时不允许修改
})
obj.name = "leslie-cheung";
console.log(obj.name);//Leslie Cheung var obj = {};
Object.defineProperty(obj,"name",{
value:"Leslie Cheung",
writable:true//为true时允许修改
})
obj.name = "leslie-cheung";
console.log(obj.name);//leslie-cheung

3、configurable

    var obj = {};
Object.defineProperty(obj,"name",{
value:"Leslie Cheung",
configurable:false//为false时不允许被删除
})
delete obj.name;
console.log(obj.name);//Leslie Cheung var obj = {};
Object.defineProperty(obj,"name",{
value:"Leslie Cheung",
configurable:true//为true时允许被删除
})
delete obj.name;
console.log(obj.name);//undefined

4、enumerable

    var obj = {name:"Leslie Cheung",age:"20"};
Object.defineProperty(obj,"name",{
enumerable:false//为false时不可被遍历
});
Object.defineProperty(obj,"age",{
enumerable:false//为false时不可被遍历
});
console.log(Object.keys(obj));//[] var obj = {name:"Leslie Cheung",age:"20"};
Object.defineProperty(obj,"name",{
enumerable:true//为true时可被遍历
});
Object.defineProperty(obj,"age",{
enumerable:true//为true时可被遍历
});
console.log(Object.keys(obj));//["name", "age"]

5、get()和set()

    var obj = {name:"Leslie Cheung"};
Object.defineProperty(obj,"name",{
get(){
console.log("被访问,触发get()方法");//被访问时触发get()方法
},
set(val){
console.log("被设置了" + val + ",触发set()方法");//被设置时触发set()方法
}
});
obj.name;//输出结果:被访问,触发get()方法
obj.name = "leslie-cheung";//输出结果:被设置了leslie-cheung,触发set()方法
注意:当使用了get()方法或者set()方法的时候就不能使用value和writable中的任何一个属性否则会报错

6、for in和Object.keys()的区别

    function Person(name,age){
this.name = name;
this.age = age;
}
Person.prototype = {
sex:"男"
}
var man = new Person("Leslie Cheung",20);
console.log(Object.keys(man));//["name", "age"],返回一个数组,数组值为对象自身的属性,不包括继承原型的属性
for(var key in man){
console.log(key);//name age sex,遍历对象可枚举的属性,包括自身的属性,以及继承原型的属性
}

Object.defineProperty的理解的更多相关文章

  1. 浅谈兔兔对Object.defineProperty的理解

    给一个对象定义一个新的属性或者在修改一个对象现有的属性,并返回这个对象 语法: Object.defineProperty(参数1,参数2,参数3) 参数1:目标对象 参数2:要修改或者添加的属性名称 ...

  2. 理解Object.defineProperty()

    理解Object.defineProperty() Object.defineProperty() 方法直接在一个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象. 基本语法:Obj ...

  3. 理解Object.defineProperty函数中的get与set

    defineProperty是什么: 该函数可以直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象.通俗理解就是: 给对象添加一个新的属性,或者针对对象里的某些属性,可以给这 ...

  4. 深入理解 Object.defineProperty 及实现数据双向绑定

    Object.defineProperty() 和 Proxy 对象,都可以用来对数据的劫持操作.何为数据劫持呢?就是在我们访问或者修改某个对象的某个属性的时候,通过一段代码进行拦截行为,然后进行额外 ...

  5. 理解 Object.defineProperty

    理解 Object.defineProperty 本文写于 2020 年 10 月 13 日 Object.defineProperty 用于在一个对象上定义新的属性或修改现有属性并返回该对象. 什么 ...

  6. 理解Object.defineProperty的作用

    对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值.定义对象可以使用构造函数或字面量的形式: var obj = new Object; //obj = {} obj.name = ...

  7. [转] 理解Object.defineProperty的作用

    对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值.定义对象可以使用构造函数或字面量的形式: var obj = new Object; //obj = {} obj.name = ...

  8. Object.defineProperty(o,p,descriptor ) 理解应用

    1. Object.defineProperty  在一个对象上定义一个新属性,或修改一个已经存在的属性, 最终返回这个对象. var __define = this.__define || func ...

  9. 《转》理解Object.defineProperty的作用

    对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值.定义对象可以使用构造函数或字面量的形式: var obj = new Object; //obj = {} obj.name = ...

随机推荐

  1. GPT转MBR怎么转?

    GPT转MBR分区怎么转?现在很多笔记本的硬盘分区都是GPT模式,如果想装XP的话,那只能将GPT磁盘转换成MBR磁盘分区才行.接下来,简单说说如何将GPT分区转成MBR分区! 如果本身电脑有两个硬盘 ...

  2. 如何区分DDR1 DDR2 DDR3内存条

    DDR1,DDR2,DDR3内存条(DDR是Double Data Rate双倍速率同步动态随机存储器的英文缩写)就是俗称的一二三代内存条.这三种内存条工艺不同,接口不同,性能不同,互不兼容.要区分它 ...

  3. Kinect2.0点云数据获取

    接上一篇:Kinect2.0获取数据 http://blog.csdn.net/jiaojialulu/article/details/53087988 博主好细心,代码基本上帖过来就可以用,注释掉的 ...

  4. 实例:使用puppeteer headless方式抓取JS网页

    puppeteer google chrome团队出品的puppeteer 是依赖nodejs和chromium的自动化测试库,它的最大优点就是可以处理网页中的动态内容,如JavaScript,能够更 ...

  5. JVM调优之jstack找出最耗cpu的线程、定位代码

    jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多.下面我们来一个实例找出某个Java进程中最耗费CPU的Java线程并定位堆栈信息,用到的命令有 ...

  6. 构造器初始化(static)

    package demo; /* * 在类 的内部,变量定义的先后顺序决定了初始化的顺序.即使变量定义散布于方法定义之间, * 它们仍旧会在任何方法(包括构造器)被调用之前得到初始化. */ publ ...

  7. 微信小程序--修改data数组或对象里面的值

    1.初始data数据 Page({     data:{          code:'1234',         reward:[{             name:"艾伦" ...

  8. MySQL更新

    1.两表更新(用一个表更新另一个表) UPDATE t_i_borrower a, t_supplier s SET a.type = s.type WHERE a.cust_id = s.cust_ ...

  9. 【LeetCode每天一题】3Sum(三数之和)

    Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = 0? Find ...

  10. jenkins配置详解之——执行者数量

    jenkins上的执行者数量的设置并不是随意设置的,位置如下: 他是跟cpu核数密切相关的,原则上是不能超过cpu的核数的, 如何查看cpu的核数呢,命令如下: # 查看物理CPU个数cat /pro ...