数据属性与访问器属性——对象(一)

(整理自网络)

ES5中对象的属性可以分为‘数据属性’和‘访问器属性’两种。

数据属性一般用于存储数据数值,访问器属性对应的是set/get操作,不能直接存储数据值。

一、数据属性特性:value、writable、enumerable、configurable。

configurable:true/false,判读是否可以delete删除属性,能否修改属性的特性,能否把属性修改为访问器属性,默认false;

enumerable:true/false,是否可以通过for in循环返回,默认true;

writable:true/false,是否可以修改属性的值,默认true;

value:undefined,设置属性的值,默认undefined。

二、访问器属性特性:set、get、enumerable、configurable。

configurable:true/false,是否可以通过delete删除属性,能否修改属性的特性,能否把属性修改为访问器属性,默认false;

enumerable:true/false,是否可以通过for in循环返回,默认false;

set:function,读取属性值时调用的函数;

get:function,修改属性值时调用的函数。

访问器属性可以起到很好的保护作用,当只有get方法时,就实现只读不能写;反之,只有set时,便是只能写入而不能读取

三、将属性添加到对象或修改现有属性的特性使用Object.defineProperty() 或 Object.defineproperties()方法(不论是数据属性还是访问器属性):

格式:Object.defineProperty(object, propertyname, descriptor):

参数解释:object:需要添加或修改属性的对象;

propertyname:属性的名称,字符串格式;

descriptor:属性的描述,设置数据属性或访问器属性的特性。

四、数据属性实例:

数据属性与访问器属性——对象(一)_第1张图片
数据属性与访问器属性——对象(一)_第2张图片

五、访问器属性实例:

_name前面的下划线是一种常用几号,用于表示只能通过对象方法(get、set)访问的属性。

数据属性与访问器属性——对象(一)_第3张图片
数据属性与访问器属性——对象(一)_第4张图片

你可能感兴趣的:(数据属性与访问器属性——对象(一))