码迷,mamicode.com
首页 > 编程语言 > 详细

javascript对象

时间:2015-12-16 15:39:07      阅读:337      评论:0      收藏:0      [点我收藏+]

标签:

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

 

javascript的对象用于描述现实世界中的某个对象。

 

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

 

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

 

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

 

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

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

 

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

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

 

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

 

var xiaoming = {
    name: ‘小明‘
};
xiaoming.age; // undefined

 

由于javascript的对象是动态类型,你可以自由地给一个对象添加或删除属性:

 

var xiaoming = {
    name: ‘小明‘
};
xiaoming.age; // undefined
xiaoming.age = 18; // 新增一个age属性
xiaoming.age; // 18
delete xiaoming.age; // 删除age属性
xiaoming.age; // undefined
delete xiaoming[‘name‘]; // 删除name属性
xiaoming.name; // undefined
delete xiaoming.school; // 删除一个不存在的school属性也不会报错

 

如果我们要检测xiaoming是否拥有某一属性,可以用in操作符:

 

var xiaoming = {
    name: ‘小明‘,
    birth: 1990,
    school: ‘No.1 Middle School‘,
    height: 1.70,
    weight: 65,
    score: null
};
‘name‘ in xiaoming; // true
‘grade‘ in xiaoming; // false
 

不过要小心,如果in判断一个属性存在,这个属性不一定是xiaoming的,它可能是xiaoming继承得到的:

 

‘toString‘ in xiaoming; // true

 

因为toString定义在object对象中,而所有对象最终都会在原型链上指向object,所以xiaoming也拥有toString属性。

 

要判断一个属性是否是xiaoming自身拥有的,而不是继承得到的,可以用hasOwnProperty()方法:

 

var xiaoming = {
    name: ‘小明‘
};
xiaoming.hasOwnProperty(‘name‘); // true
xiaoming.hasOwnProperty(‘toString‘); // false

javascript对象

标签:

原文地址:http://www.cnblogs.com/zhouguowei/p/5051224.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!