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”
}
第二种:通过关键字创建对象。
关键字new用来创建并初始化对象,后面跟一个构造函数。JavaScript语言核心中原始类型都包含内置构造函数,下面是内置对象创建演示。
var o = new Object(); //创建一个空对象,等价于 0={}
var a = new Array(); //创建一个空数组
var d = new Date(); //创建一个代表当前时间的Date对象
var r = new RegExp(“js”); //创建一个正则表达式对象
第三种:使用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的自有属性
3.删除属性
delete运算符可以删除对象的属性,删除成功返回true。但是delete不能删除那些可配置型为false的属性。只能删除自身属性,不能删除继承属性。
Delete book.Auto
删除全局属性时,可以直接省略全局对象,delete后面跟上要删除的属性+
This.x=1;
Console.log(delete x);
4.检测属性
所谓检测属性就是判断某个属性时候存在与某个对象中。一般可以通过in运算符、hasOwnProperty()和propertyIsEnumerable()方法来完成验证工作。
in运算符判断,如果对象自有属性或继承属性包含这个属性则返回true。
var o = { “x”: 5 };
console.log(“x” in o); //=>true 对象o有属性x
console.log(“y” in o); //=>false 对象o没有属性x
console.log(“toString” in o); //=>true 对象o继承属性toString