对象设置属性的方法defineProperty和defineProperties

一、defineProperty方法

基础语法

Object.defineProperty(对象,“属性名”,描述对象);

描述对象中的属性及其各自的作用:

属性名作用
configurable是否可以删除该属性或者修改该属性的定义描述对象
enumerable该属性是否可枚举
writable该属性是否可修改
get获取该属性值时调用该函数
set设置该属性值时调用该函数
value该属性的值或者方法

注意:

  • 默认configurable,enumerable,writable的值都是false
  • (set,get)和(value,writable)冲突

调用形式举例

1、(set,get)

	var o = { a: 1 };
	
	Object.defineProperty(o, "c", {
		enumerable: true,
		configurable: true,
		set: function (value) {
		  this._c = value;
		},
		get: function () {
		  return this._c;
		},
	});

这里的set和get就类似于java中的setter和getter。

2、(value,writable)

	Object.defineProperty(o, "b", {
	  configurable: true, //是否可以删除该属性或者修改该属性的定义描述对象
	  enumerable: true, //该属性是否可枚举
	  writable: false, //该属性是否可修改,可以定义对象中的常量属性,默认是false
	  value: 4, //value就是这个属性的值,如果value是一个函数,b就是一个方法
	});

注意:

1、一般defineProperty方法不用来定义类(class)的静态属性,而是用来定义实例化对象的静态属性。
因为类里面是不能使用const来定义常量的,所以只能在类的初始化方法constructor中使用Object.defineProperty()。

      class Box {
        constructor() {
          Object.defineProperty(this, "ROW", {
            configurable: true,
            enumerable: true,
            value: 5,
          });
        }
        play() {
          console.log(this.ROW);
        }
      }

      var b=new Box();
      console.log(b.ROW); //5
      b.play(); //5

2、不能修改原型链

	var o = { a: 1 };
	Object.defineProperty(o, "__proto__", {
		configurable: true,
		enumerable: true,
		writable: true,
		value: "a",
	});
	console.log(o);

打印结果如图:打印结果
我们看到在上面有一个__proto__属性并且其值是"a",而在下面的原型属性__proto__依旧存在。

在这里我们要注意,原型链是对象中特有的东西,当我们给一个对象添加__proto__属性时,我们可以设置成功,但是它并不能覆盖原本的原型属性__proto__。
所以当我们调用__proto__属性时,是可以获取到我们设置的那个__proto__属性对应的属性值的;而因为对象原本的__proto__原型属性并没有被覆盖,所以在原型链上的属性和方法我们依旧可以获取和调用。

所以说,defineProperty方法不能修改原型链。

二、defineProperties方法

根据这个方法的名字我们就可以看出,这个方法是设置多个属性的,它除了可以一次设置多个属性以外,和defineProperty方法基本没什么区别,所以我们通过下面这个例子来了解这个方法的使用方式。

      var o = {};
      var c = Symbol();
      Object.defineProperties(o, {
        "a": {
          value: 1,
        },
        b: {
          enumerable: true,
          configurable: true,
          value: 5,
        },
        [c]: {
          writable: true,
          value: 10,
        },
      });
      console.log(o); 

打印结果如下:
在这里插入图片描述
根据上面的描述对象和打印结果,我们可以确定,不可删除或修改描述对象以及不可枚举的属性有"a"和[c],不可修改值的属性有"a"和b。

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值