怎样读取属性的特性

读取属性的特性

使用Object.getOwnPropertyDescriptor()方法可以去的指定属性的属性描述符。这个方法接收两个参数:属性所在的对象和要取得其描述符的属性名。返回值是一个对象,对于访问其属性包含configurable,enumerable,get和set属性,对于数据属性包含configurable,enumberable,writable和value属性。比如:`

let book = {};
object.definePeroperties(book,{
	year_: {
		value: 2017
		},
	edition: {
		value: 1
		},
	year: {
		get: funtion() {
			return this.year_;
		},

	set:function(newValue){
		if (newValue > 2017) {
			this.year_ = newValue;
			this.edition += newValue - 2017;
			}
		}
	}
};
  let descriptor = Object.getOwnPropertyDescriptor(book, "year_");
console.log(descriptor.value);                     //  2017
console.log(descriptor.configurable);         //  false
console.log(typeof descriptor.get);            //  "undefined"
let descriptor = Object.getOwnPropertyDescriptor(book, "year");
console.log(descriptor.Value);                  // undefined
console.log(descriptor.enumerable);       // false
console.log(typeof descriptor.get);          // "function"

对于数据属性year_,value等于原来的值,configurable是false,get是undefined。对于访问器属性year,value是undefined,enuemerable是false,get是一个指向获取函数的指针。
ECMAScrapt2017新增了Object,getOwnPropertyDescriptors()静态方法。这个方法实际上在每个自有属性上调用Object。defineProperties()并在一个新对象中返回它们。对于前面的例子,使用这个静态方法会返回如下对象:

let book = {};
Object.defineProperties(book, {
	year_: {
		value: 2017
	},
	edition: {
		value: 1
	},

	year: {
		get: function() {
			return this.year_;
	},

	set: function(newValue){
		if (newValue > 2017) {
			this.year_ = newValue;
			this.edition += newValue - 2017;
			}
		}
	}
});
console.log(Object.getOwnPropertyDescriptors(book));
//  (
//     configurable: false,
//     enumerable: false,
//     value: 1,
//     writable: false
//   ),
//   year: (
//     configurable: false,
//     enumerable: false,
//     get: f(),
//     set: f(newValue),
//   ),
//   year_: (
//     configurable: false,
//     enumerable: false,
//     value: 2019,
//     writable: false
//   )
// )
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值