javascript对象
2015-12-16 15:04
489 查看
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 : '小明',
age : 18,
'your-school' : 'No.1 Middle School',
height : 1.78,
weight : 65
};
document.write(xiaoming.name + '<br>');//访问对象属性
document.write(xiaoming['your-school'] + '<br>');//访问含有特殊字符的属性名
document.write(xiaoming['height'] + '<br>');
xiaoming.name = '改名字啦';//动态改变属性
document.write('删除属性开始<br>');
document.write(xiaoming.friends + '<br>');//访问不存在的属性,返回undefined
delete xiaoming.name;//删除对象属性
for(x in xiaoming){
document.write(xiaoming[x] + '<br>');
}
if('weight' in xiaoming){//检查xiaoming是否拥有weight这个属性
document.write('weight属于对象xiaoming的属性<br>');
}
if('toString' in xiaoming){//检查xiaoming是否拥有toString这个属性,toString定义在对象中
document.write('toString属于对象xiaoming的属性<br>');
}
if(xiaoming.hasOwnProperty('toString')){//检查xiaoming是否拥有toString这个属性
document.write('toString属于对象xiaoming的属性<br>');
}else{
document.write('toString不属于对象xiaoming的属性<br>');
}
运行结果:
小明No.1 Middle School1.78删除属性开始undefined18No.1 Middle School1.7865weight属于对象xiaoming的属性toString属于对象xiaoming的属性toString不属于对象xiaoming的属性
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 : '小明',
age : 18,
'your-school' : 'No.1 Middle School',
height : 1.78,
weight : 65
};
document.write(xiaoming.name + '<br>');//访问对象属性
document.write(xiaoming['your-school'] + '<br>');//访问含有特殊字符的属性名
document.write(xiaoming['height'] + '<br>');
xiaoming.name = '改名字啦';//动态改变属性
document.write('删除属性开始<br>');
document.write(xiaoming.friends + '<br>');//访问不存在的属性,返回undefined
delete xiaoming.name;//删除对象属性
for(x in xiaoming){
document.write(xiaoming[x] + '<br>');
}
if('weight' in xiaoming){//检查xiaoming是否拥有weight这个属性
document.write('weight属于对象xiaoming的属性<br>');
}
if('toString' in xiaoming){//检查xiaoming是否拥有toString这个属性,toString定义在对象中
document.write('toString属于对象xiaoming的属性<br>');
}
if(xiaoming.hasOwnProperty('toString')){//检查xiaoming是否拥有toString这个属性
document.write('toString属于对象xiaoming的属性<br>');
}else{
document.write('toString不属于对象xiaoming的属性<br>');
}
运行结果:
小明No.1 Middle School1.78删除属性开始undefined18No.1 Middle School1.7865weight属于对象xiaoming的属性toString属于对象xiaoming的属性toString不属于对象xiaoming的属性
相关文章推荐
- jsp页面设置防止写EL表达式时中文乱码
- 【Javascript】替换元素节点replaceChild()
- 【js小方法】提交表单是,判断单选框是否被选中
- JSON笔记
- ECharts图表插件禁止拖动合并
- typeof instanceof 的应用场景
- javascript(小技巧)
- JS内部对象(window,navigator)
- js 为label标签和div标签赋值
- javascript数组
- Javascript中的substring和substr区别
- 【特效】无意中出现的炫酷特效
- js模拟百度主页搜索功能
- 【特效】js打造黑客帝国文字特效
- jshint相关的配置
- VS快速生成JSON数据格式对应的实体
- JS与C#编码解码
- javascripts小结
- js常用函数
- js函数Math random()、ceil()、floor()、round() 比较