JS对象(1)

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



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值