1.1 数据属性(`properties`),对象的普通属性将字符串名称映射到值。例如,下面对象obj有一个数据属性,名称为 prop,对应的值为 123:var obj = {prop: 123}可以用以下方式读取属性的值:console.log(obj.prop)// 123,console.log(obj["prop"])// 123,当然也可以用以下方式来设置属性的值:obj.prop = "abc"obj["prop"] = "abc"
1.2 访问器属性,另外,可以通过函数处理获取和设置属性值。 这些函数称为访问器函数。 处理获取的函数称为getter。 处理设置的函数称为setter:var obj = {get prop () {return 'Getter'},set prop (value) {console.log('Setter: ' + value)}}访问 obj 属性:>obj.prop'Getter'>obj.prop = 123Setter: 123。
1.3 内部属性一些属性只是用于规范,这些属于“内部”的属性,因为它们不能直接访问,但是它们确实影响对象的行为。内部属性有特殊的名称都写在两个方括号,如:内部属性[[Prototype]]指向对象的原型。它可以通过Object.getPrototypeOf()读取。它的值只能通过创建具有给定原型的新对象来设置,例如通过object.create()或__proto__ 。
内部属性[[Extensible]]决定是否可以向对象添加属性。可以通过Object.isExtensible() 方法判断一个对象是否是可扩展的(是否可以在它上面添加新的属性)。可以通过Object.preventExtensions()方法让一个对象变的不可扩展,也就是永远不能再添加新的属性。
属性特性(attribute),属性的所有状态,包括数据和元数据,都存储在特性(attribute)中。它们是属性具有的字段,就像对象具有属性一样。特性(attribute)键通常用双括号编写:
JS中万物都是对象,今天就深度讲一下Object的里面到底有什么。文章主要讲对象的自有属性和原型中的属性,至于原型链就不在这篇文章多讲了。
创建对象的方法有如下几种
Object.assign() 方法用于将其他对象的可枚举属性复制到目标对象(即第一个参数对象)
常用于将某个对象合并到新对象{}。
常用于继承某个构造函数的原型属性,但是不能继承该构造函数的实例属性,例如上面例子
该属性是实现vue双向数据绑定的核心,这里主要讲它的使用方法。
讲它的相关用法时,就得先理解 的概念。
1.数据属性
数据属性的四个特性
configurable: 表示是否能被delete删除属性且能重新定义该属性。
enumerable: 表示能否通过for-in遍历的属性。
writable: 表示是否能修改属性。
value: 属性的值。
2.访问器属性
数据属性不包含数据值,包含一对get和set的核心方法,在读取访问器属性时,就是通过这两个方法进行操作处理的。
访问器属性的四个特性
configurable: 表示是否能被delete删除属性且能重新定义该属性。
enumerable: 表示能否通过for-in遍历的属性。
get: 读取属性时调用的方法,默认值是undefined。
set: 写入属性时调用的方法,默认值是undefined。
从图中可以看到访问器属性的configurable和enumerable两个属性的默认值都是false,如果后面要对该访问器属性进行delete删除时,将configurable转化成true即可。
从图可以看出该对象具有四个属性,
(defineProperty、defineProperties、getOwnPropertyDescriptor、getOwnPropertyDescriptors)
这四个属性是分为两对:defineProperty vs getOwnPropertyDescriptor、defineProperties vs getOwnPropertyDescriptors。
意思为属性设置和属性的获取解析,第一对上面讲过了,这里就大概说一下第二对的意思,也就是支持设置对个属性,获取多个属性的意思。
Object.defineProperties()
Object.getOwnPropertyDescriptors()
打印出对象的所有属性
Object.entries() 方法返回一个给定对象
Object转Map
new Map()构造函数接受一个二维数组,而Object.entries()方法生成一个二维数组,所以对象、数组、字数串转化为Map结构变得简单。
正常对象的数据属性都可以被 但是通过以下方法,改变了数据属性的四大特性。
相对应的检测方法,返回Boolean。
举例
Object.freeze()方法可冻结对象,冻结后,对象属性不能删除,修改以及添加,只能for...in读取。
该对象方法和==与===运算符相似,但是有明显区别。
Object.is与==比较
== 会将两边的操作数进行隐式转化,之后再进行比较,但是Object.is就不会进行转化。
Object.is与===比较
=== NaN和NaN不等,-0与+0相等,但是Object.is就认为NaN和NaN是相等,而-0和+0是不相等的。
所以总的来说这两个的相似程度比== 运算符更相近。
Object.keys()返回一个 名称(键)的数组
Object.values()返回可枚举属性值得数组
Object.setPrototypeOf(obj, prototype)
为对象obj设置新的原型对象。
注意
如果对象的[[Prototype]]被修改成不可扩展(通过 Object.isExtensible() 查看),就会抛出 TypeError 异常。如果 prototype 参数不是一个对象或者 null (例如,数字,字符串,boolean,或者 undefined ),则什么都不做。否则,该方法将 obj 的 [[Prototype]] 修改为新的值。
下篇文章 JS 对象(Object)的深入解析—原型属性
访问对象属性首先从自身找,然后从原型链上找,找到则返回,没找到返回undefined.
// 构造函数function Foo(name) {
this.name = name
}
var foo = new Foo('Tom') // 实例对象
console.log(foo.name) // Tom 自身找到直接返回
console.log(foo.toString())
/**
* 自身没有 toString 方法,从隐式原型链上找 foo.__proto__ = Foo.prototype => Foo.prototype.__proto__ = Object.prototype
*/