Javascript 对象总结:
JavaScript对象可以看作是属性的无序集合,每个属性就是一个键值对,可增可删。
JavaScript中的所有事物都是对象:字符串、数字、数组、日期,等等。
JavaScript对象除了可以保持自有的属性外,还可以从一个称为原型的对象继承属性。对象的方法通常是继承的属性。这种“原型式集成”是JavaScript的的核心特征。
1.创建对象
第一种:对象直接量表示法创建对象。
这是最简单的对象创建方式,对象直接量由若干key:value键值对属性组成,属性之间用逗号分隔,整个对象用花括号括起来。
var empty = {}; //不包含任何属性的对象 var point = { x: 3, y: 5 }; //包含两个属性的对象 var point2 = { x: point.x + 1, y: point.y + 1 }; //属性值可以是表达式 var book = { "main title": "JavaScript", //属性名有空格,必须用字符串表示 "sub-title": "The Defintive Guide", //属性名有连字符,必须用字符串表示 "for": "all audiences", //属性名是保留字,必须用字符串表示 author: { //这个属性的值是一个对象 firstname: "David", surname: "Flanagan" }
ECMAScript 5版本中,使用保留字属性名可以不用引号引起来。对象直接量最后一个属性后的逗号自动忽略。
第二种:通过关键字创建对象。
关键字new用来创建并初始化对象,后面跟一个构造函数。JavaScript语言核心中原始类型都包含内置构造函数,下面是内置对象创建演示。
var o = new Object(); //创建一个空对象,等价于 0={} var a = new Array(); //创建一个空数组 var d = new Date(); //创建一个代表当前时间的Date对象 var r = new RegExp("js"); //创建一个正则表达式对象
除了这些内置构造函数,使用自定义构造函数来初始化新对象也很常见。
介绍第三种方法之前需要先简单了解“原型”的概念。每一个JavaScript对象(null除外)都有一个关联对象,并且可以从关联对象继承属性。这个关联对象就是所谓的“原型”,类似于C#中的基类。
所有通过对象直接量和构造函数创建的对象都可以通过Object.prototype获得原型对象的引用。没有原型的对象为数不多,Object.prototype就是其中之一。
普通对象都有原型,比如Array数组对象的原型是Array.prototype。同时,内置构造函数都具有一个继承Object.prototype的原型。因此,通过new Array()创建的数组对象的属性同时继承至Array.prototype和Object.prototype,当对象出现多继承关系时,那么这一系列链接的原型对象就被称作“原型链”。
第三种:使用Object.create()函数创建对象。
Object.create(Object[,Properties])是ECMAScript 5版本出现的一个静态函数,用来创建对象。它接收两个参数:第一个是要创建对象的原型;第二个是可选参数,用来描述对象属性。
使用它创建对象,只需传入所需原型对象即可:
var a = Object.create({ 'isLock': true }); //为对象a指定一个原型 console.log(a.isLock); //=> true o继承原型对象属性isLock console.log(a.hasOwnProperty('isLock')); //=> false 验证isLock并非o的自有属性
创建一个普通的空对象,需要传入参数Object.prototype:
var b = Object.create(Object.prototype);
可以通过传入参数null来创建没有原型的对象,该类对象不会继承任何东西:
var b = Object.create(null); //该对象不包括任何对象的基础方法
通过原型创建对象,可以使任意对象可继承,这是一个强大的特性。比如可以防止程序无意修改不受控制的对象。程序不直接操作对象,而是操作通过Object.create()创建的继承对象。
2.查询和设置属性
对象属性值可以通过点.和方括号[]运算符来查询或设置。
var book = { 'author': 'Tom', 'main title': 'Hello JavaScript' }; var author = book.author; //1.获取book的“author”属性值 var title = book["main title"]; //2.获取book的“main title”属性值 book.edition = 6; //3.给book创建一个“edition”属性 book["main title"] = "ECMAScript"; //4.修改"main title"属性值
ES3版本中,如果属性名是关键字必须通过方括号的形式访问。ES5版本放宽了要求,可以直接在点运算符后面直接使用保留字。
关联数组对象
上面提到可以通过object["property"]操作对象属性,这种语法看起来更像数组,只是这个数组元素是通过字符串索引而不是数字索引,这类数组被称为关联数组。JavaScript对象都是关联数组,通过[]访问对象属性时,在程序运行时可以创建或修改它们,更有灵活性。
继承