JavaScript 属性的特性

1.基本概念
JS对象:无序属性的集合,其属性可以包含基本值、对象或函数。属性又分为数据属性和访问器属性。
ECMAScript为了描述对象属性(property)的各种特征,定义了特性(attribute)这个概念。

2.数据和访问器

数据特征含义
[[Configurable]]表示能否通过delete删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为访问器属性。
[[Enumerable]]表示是否是可枚举类型(能否用for-in循环返回属性)。
[[Writable]]表示能否修改数据值。
[[Value]]包含这个属性的数据值,读写都在这个特征值上进行。默认undefined。
访问器特征含义
[[Configurable]]表示能否通过delete删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为访问器属性。
[[Enumerable]]表示是否是可枚举类型(能否用for-in循环返回属性)。
[[Get]]在读取属性时调用的函数。默认undefined。
[[Set]]在写入属性时调用的函数。默认undefined。

- 获取特征的方法

var person = {
    name: "FAFA",
    age: 18
}
Object.getOwnPropertyDescriptor(person,"name");

3.设置和访问的方式

  • 设置特征
var person = {
    name: "FAFA",
    age: 18
}
Object.defineProperty(person,"name",{
    configurable : true,
    enumerable : false,
    writable : true
});
for(var i in person){
    console.log(i);//只有age被枚举到
}
  • 同时设置多个属性的特征
var person = {
    name: "FAFA",
    age: 18
}
//同时设置多个属性的特征
Object.defineProperties(person,{
    name:{
       configurable : true,
       enumerable : false,
       writable : true
    },
    age:{
       configurable : true,
       enumerable : false,
       writable : true
    }
});
for(var i in person){
    console.log(i);//都枚举不到
}
  • 设置访问器的特征
var person = {
    name : "FAFA",
    _age : 18,
    edition : 0
}
Object.defineProperty(person,"age",{
    get : function(){
        return this._age;
    },
    set :function(n){//值指定get不指定set则默认该属性是只读的。
        this._age = n;
        this.edition ++;
    }
});
//只指定getter意味着属性时不能写,尝试写入属性会被忽略、
//在严格模式下,尝试写入只制定了getter函数的属性会抛出错误。
//只指定了setter函数的属性也不能读,否则在非严格模式下返回undefined。
//在严格模式下会抛出错误。
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值