JavaScript 中所有變量都是對(duì)象,除了兩個(gè)例外 null 和 undefined。
false.toString(); // 'false'
[1, 2, 3].toString(); // '1,2,3'
function Foo(){}
Foo.bar = 1;
Foo.bar; // 1
一個(gè)常見(jiàn)的誤解是數(shù)字的字面值(literal)不是對(duì)象。這是因?yàn)?JavaScript 解析器的一個(gè)錯(cuò)誤, 它試圖將點(diǎn)操作符解析為浮點(diǎn)數(shù)字面值的一部分。
2.toString(); // 出錯(cuò):SyntaxError
有很多變通方法可以讓數(shù)字的字面值看起來(lái)像對(duì)象。
2..toString(); // 第二個(gè)點(diǎn)號(hào)可以正常解析
2 .toString(); // 注意點(diǎn)號(hào)前面的空格
(2).toString(); // 2先被計(jì)算
JavaScript 的對(duì)象可以作為哈希表使用,主要用來(lái)保存命名的鍵與值的對(duì)應(yīng)關(guān)系。
使用對(duì)象的字面語(yǔ)法 - {} - 可以創(chuàng)建一個(gè)簡(jiǎn)單對(duì)象。這個(gè)新創(chuàng)建的對(duì)象從 Object.prototype
繼承下面,沒(méi)有任何自定義屬性。
var foo = {}; // 一個(gè)空對(duì)象
// 一個(gè)新對(duì)象,擁有一個(gè)值為12的自定義屬性'test'
var bar = {test: 12};
有兩種方式來(lái)訪問(wèn)對(duì)象的屬性,點(diǎn)操作符或者中括號(hào)操作符。
var foo = {name: 'kitten'}
foo.name; // kitten
foo['name']; // kitten
var get = 'name';
foo[get]; // kitten
foo.1234; // SyntaxError
foo['1234']; // works
兩種語(yǔ)法是等價(jià)的,但是中括號(hào)操作符在下面兩種情況下依然有效
刪除屬性的唯一方法是使用 delete 操作符;設(shè)置屬性為 undefined 或者 null 并不能真正的刪除屬性,
而僅僅是移除了屬性和值的關(guān)聯(lián)。
var obj = {
bar: 1,
foo: 2,
baz: 3
};
obj.bar = undefined;
obj.foo = null;
delete obj.baz;
for(var i in obj) {
if (obj.hasOwnProperty(i)) {
console.log(i, '' + obj[i]);
}
}
上面的輸出結(jié)果有 bar undefined 和 foo null - 只有 baz 被真正的刪除了,所以從輸出結(jié)果中消失。
var test = {
'case': 'I am a keyword so I must be notated as a string',
delete: 'I am a keyword too so me' // 出錯(cuò):SyntaxError
};
對(duì)象的屬性名可以使用字符串或者普通字符聲明。但是由于 JavaScript 解析器的另一個(gè)錯(cuò)誤設(shè)計(jì),
上面的第二種聲明方式在 ECMAScript 5 之前會(huì)拋出 SyntaxError 的錯(cuò)誤。
這個(gè)錯(cuò)誤的原因是 delete 是 JavaScript 語(yǔ)言的一個(gè)關(guān)鍵詞;因此為了在更低版本的 JavaScript 引擎下也能正常運(yùn)行,
必須使用*字符串字面值*聲明方式。