书上看到的一些关于js对象

书上看到的一些关于js对象

对象的属性特性: 除了名字和值之外,每个属性还有与之相关的一些值,成为属性特性。

  • 可写(writable):表明可以设置的属性。
  • 可枚举(enumerable):可通过for/in循环返回的属性。
  • 可配置(configurable):表明是否可以删除或修改的属性。
Object.getOwnPropertyDescriptor({x:1},"x")//{value: 1, writable: true, enumerable: true, configurable: true}

Object.getOwnPropertyDescriptor可以获取对象属性的特性,可以看出属性的值也属于属性的特性。
可以用Object.defineProperty()或Object.defineProperties()来设置属性的同时,来设置属性的特性:

var p = Object.defineProperties({},{
    y:{value:1, writable:true, enumerable:true,configurable:true},
    full:{value:function(){return this.y;}, enumerable:true, configurable:true}
});
console.log(p)//{y: 1, full: undefined}
Object.getOwnPropertyDescriptor(p,"y")//{value: 1, writable: true, enumerable: true, configurable: true}
Object.getOwnPropertyDescriptor(p,"full")//{writable: false, enumerable: true, configurable: true, value: ƒ}

对象特性:

  • 对象的原型(prototype)指向另一个对象,本对象的属性继承自它的原型对象。
  • 对象的类(class)是一个标识对象类型的字符串。
  • 对象的扩展标记(extension flag)指明了是否可以向该对象添加新的属性。

对象的类: 可以调用对象的toString()方法,然后提取已返回的字符串的第8个到倒数第二个位置之间的字符。

var p = {name:"vincent",age:4};
Object.prototype.toString.call(p).slice(8,-1);//"Object"

对象的扩展标记 :通过Object.isExtensible()来判断对象是否可扩展。

Object.isExtensible(p);//true

可通过调用Object.preventExtensions();来使对象不可扩展。只是不可逆。

Object.preventExtensions(p);
Object.isExtensible(p);//false

还有一些其他的方法Object.seal()除了将对象的属性设置为不可扩展,还将对象的属性设置为不可配置;Object.isSealed()检测对象是否是封闭的。
Object.freeze()将对象属性设置为不可扩展,不可配置之外,还将自有的数据属性设置为只读(setter方法仍然可以给属性赋值);Object.isFrozen()检测对象是否冻结。

对象和属性的区分

  • 内置对象(native object) 由ECMAScript规范定义的对象或类。例如,数组,函数,日期和正则表达式。
  • 宿主对象(host object) 由JavaScript解释器所嵌入的宿主环境定义。客户端JavaScript中表示网页结构的HTMLelement对象都是宿主对象。既然宿主环境定义的方法可以当成普通的JavaScript函数对象,那么宿主对象也可以当成内置对象。
  • 自定义对象(user-defined object) 由运行中的JavaScript代码创建的对象。
  • 自有属性(own property) 是直接在对象中定义的属性。
  • 继承属性(inherited property) 在对象的原型对象中定义的属性。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值