标签:
一、object类型
一个object就是一系列属性的集合,一个属性包含一个名字(属性名)和一个值(属性值)。
object对于在应用程序中存储和传输数据而言,是非常理想的选择
二、创建object
创建object实例有两种方法:
2.1使用new 操作符后跟object构造函数创建object实例:
1 var person = new Object(); 2 person.name = "Nicholas"; 3 person.age = 29;
和其他 javascript 变量一样,对象的名字(可以是普通的变量)和属性的名字都是大小写敏感的。
2.2使用对象字面量表示法创建object实例:
1 var person = { 2 name : "Nicholas", 3 age : 29 4 };
每个属性用”,“隔开,最后一个属性不能加”,“否则在某些浏览器中会报错。
2.2.1在使用字面量表示法时,属性名也可以用字符串表示:
1 var person = { 2 "name" : "Nicholas", 3 "age" : 29, 4 5:true 5 };
这个例子包含3个属性:name、age、5,这里的数值属性名会自动转化成字符串。
2.2.2在使用对象字面量表示法时,如果留空{},则可以定义只包含默认属性和方法的对象:
1 var person = {}; 2 person.name = "Nicholas"; 3 person.age = 29;
向函数传递大量可选参数时,建议使用字面量表示法:
1 function displayInfo(args) { 2 var output = ""; 3 4 if (typeof args.name == "string"){ 5 output += "Name: " + args.name + "\n"; 6 } 7 8 if (typeof args.age == "number") { 9 output += "Age: " + args.age + "\n"; 10 } 11 12 alert(output); 13 } 14 15 displayInfo({ 16 name: "Nicholas", 17 age: 29 18 }); 19 20 displayInfo({ 21 name: "Greg" 22 });
首先使用typeof操作符检测每个属性是否存在,然后再针对这个属性执行操作。
三、object属性表示法
3.1点表示法
1 var person = { 2 "name" : "Nicholas", 3 "age" : 29 4 }; 5 6 alert(person.name); 7 alert(person.age);
最后两行就是用点表示法获取object属性的。
3.2[]表示法
如下:
1 var myCar = new Object(); 2 myCar.make = "Ford"; 3 myCar.model = "Mustang"; 4 myCar.year = 1969; 5 alert(myCar["make"]+myCar["model"]+myCar["year"]);
最后一行就是用[]表示法来获取object属性的。
因为每个属性都有一个用于访问它的字符串值(也就是键:值对中的键),所以对象有时也被叫作关联数组。
var pName="name";
alert(cat[pName]);
cat["lovely brother"]="Tom"; 属性名中包含空格所以不能使用点表示法访问它。
四、枚举一个对象的所有属性
4.1for...in 循环
该方法依次访问一个对象的自身属性及其原型链中所有可枚举的属性。
1 var obj = {a:1, b:2, c:3}; 2 for (var prop in obj) { 3 console.log("obj." + prop + " = " + obj[prop]); 4 }
prop是属性名。obj[prop]是用[]的方法获取对象的属性值。
4.2Object.keys(o)
该方法返回一个对象自身包含(不包括原型中)的所有属性的名称的数组,该数组所有值均为字符串。
1 var obj={"No1":"a","No2":"b"} 2 alert(Object.keys(obj));
4.3Object.getOwnPropertyNames(o)
该方法返回一个数组,它包含了对象 o
所有拥有的属性(无论是否可枚举)的名称。
(未完待续。。。)
从头开始学JavaScript (十一)——Object类型
标签:
原文地址:http://www.cnblogs.com/yxField/p/4228623.html