首页 > 代码库 > JavaScript对象
JavaScript对象
JavaScript的对象是一种无序的集合数据类型,它由若干键值对组成。
JavaScript用一个{...}
表示一个对象,键值对以xxx: xxx
形式申明,用,
隔开。注意,最后一个键值对不需要在末尾加,
,如果加了,有的浏览器(如低版本的IE)将报错。
访问属性是通过.
操作符完成的,但这要求属性名必须是一个有效的变量名。如果属性名包含特殊字符,就必须用‘‘
括起来:
var person={ name: ‘test‘, birth: 1900, age: 11, sex: ‘男‘,
grate-test:‘hh‘ };
上述对象申明了一个name
属性,值是‘test‘
,birth
属性,值是1900
,以及其他一些属性。最后,把这个对象赋值给变量person后,就可以通过变量person来获取person的属性了:
person.name;//test person.birth;//1900
访问包含特殊字符的属性无法使用.
操作符,必须用[‘xxx‘]
来访问:
person[‘grate-test‘];//hh
person[‘name‘];//test
也可以用person[‘name‘]
来访问person
的name
属性,不过person.name
的写法更简洁。我们在编写JavaScript代码的时候,属性名尽量使用标准的变量名,这样就可以直接通过object.prop
的形式访问一个属性了。
实际上JavaScript对象的所有属性都是字符串,不过属性对应的值可以是任意数据类型。
如果访问一个不存在的属性会返回什么呢?JavaScript规定,访问不存在的属性不报错,而是返回undefined
:
person.grade;//undefined
由于JavaScript的对象是动态类型,你可以自由地给一个对象添加或删除属性:
person.grade=‘senior‘;//添加grade属性
delete person.age;//删除age属性
如果我们要检测person是否拥有某一属性,可以用in
操作符:
‘name‘ in person;//true ‘parent‘ in person;//false
不过要小心,如果in
判断一个属性存在,这个属性不一定是person
的,它可能是person继承得到的:
‘toString‘ in person;//true
因为toString
定义在object
对象中,而所有对象最终都会在原型链上指向object
,所以person
也拥有toString
属性。
要判断一个属性是否是person自身拥有的,而不是继承得到的,可以用hasOwnProperty()
方法:
person.hasOwnProperty(‘name‘);//true person.hasOwnProperty(‘toString‘);//false
JavaScript对象