1.对象的语法
对象来自于两种形式:声明形式 and 构造形式
一个对象的字面语法是这样:
var obj = {
key:value
}
构造形式是这样:
var obj = new Object();
obj.key = value;
在JavaScript中的六种主要的类型有:string number boolean null undefine object
这里的前五个为简单基本类型,但是它们并不是object,null被当做object,也只是个错误。
var str = 'I am a string';
console.log(str.length);
console.log(str.charAt(3));
在字符串的基本类型上调用属性和方法,引擎会自动的将它转换为String对象。但是
var str = 'i am a string';
console.log(typeof str);//string
console.log(str instanceof String);//false
var a = new String('haha');
console.log(typeof a);//object
console.log(a instanceof String);//true
借此来说明一下,instanceof 和 typeof的区别:
typeof 一般只能返回如下几个结果:
number,boolean,string,function,object,undefined。我们可以使用 typeof 来获取一个变量是否存在,如 if(typeof a!="undefined"){alert("ok")},而不要去使用 if(a) 因为如果 a 不存在(未声明)则会出错,对于 Array,Null 等特殊对象使用 typeof 一律返回 object,这正是 typeof 的局限性。
而a instanceof b用于判断a是否是b的实例,它检测的object是js语法中的object,不是指dom模型对象,但是,
alert(typeof(window))会得object ,window instanceof Object 会返回false.
2.对象的属性访问
对象的属性访问有两种形式,如下:
var obj = {
a:2
};
obj.a;//2 属性访问
obj['a'];//2 键访问
二者的区别在于后者的属性名可以是变量,且更加随意。
var b = true;
var id;
var obj = {
a:2
};
if(b){
id='a';
}
console.log(obj[id]);//2
在对象中,属性名总是由字符串表示的,如果是其他类型的值,它会首先被转换为字符串。
var a = {};
a[true]='f';
a[3]='b';
a[a]='c';
a['true'];//'f'
a['3'];//b
a['[object Object]'];//c