0
点赞
收藏
分享

微信扫一扫

js对象|20

JavaScript的对象是一种无序的集合数据类型,它由若干键值对组成。

JavaScript的对象用于描述现实世界中的某个对象。例如,为了描述“小明”这个淘气的小朋友,我们可以用若干键值对来描述他:

var xiaoming = {
name: '小明',
birth: 1990,
school: 'No.1 Middle School',
height: 1.70,
weight: 65,
score: null

JavaScript用一个​​{...}​​表示一个对象,键值对以​​xxx: xxx​​形式申明,用​​,​​隔开。注意,最后一个键值对不需要在末尾加​​,​​,如果加了,有的浏览器(如低版本的IE)将报错。

上述对象申明了一个​​name​​属性,值是​​'小明'​​,​​birth​​属性,值是​​1990​​,以及其他一些属性。最后,把这个对象赋值给变量​​xiaoming​​后,就可以通过变量​​xiaoming​​来获取小明的属性了:

xiaoming.name; // '小明'
xiaoming.birth; // 1990

访问属性是通过​​.​​操作符完成的,但这要求属性名必须是一个有效的变量名。如果属性名包含特殊字符,就必须用​​''​​括起来:

var xiaohong = {
name: '小红',
'middle-school': 'No.1 Middle School'
};

​xiaohong​​的属性名​​middle-school​​不是一个有效的变量,就需要用​​''​​括起来。访问这个属性也无法使用​​.​​操作符,必须用​​['xxx']​​来访问:

xiaohong['middle-school']; // 'No.1 Middle School'
xiaohong['name']; // '小红'
xiaohong.name; // '小红'

也可以用​​xiaohong['name']​​来访问​​xiaohong​​的​​name​​属性,不过​​xiaohong.name​​的写法更简洁。我们在编写JavaScript代码的时候,属性名尽量使用标准的变量名,这样就可以直接通过​​object.prop​​的形式访问一个属性了。

实际上JavaScript对象的所有属性都是字符串,不过属性对应的值可以是任意数据类型。

如果访问一个不存在的属性会返回什么呢?JavaScript规定,访问不存在的属性不报错,而是返回​​undefined​​:

'use strict';

var xiaoming = {
name: '小明'
};

举报

相关推荐

0 条评论