js 中{},[]中括号,大括号使用详解



增加 减小] 类型:转载

<!--end art_info-->


 



{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数



 



 



<!--NEWSZW_HZH_BEGIN--> 一、{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数。 如:var LangShen = {"Name":"Langshen","AGE":"28"};
上面声明了一个名为“LangShen”的对象,多个属性或函数用,(逗号)隔开,因为是对象的属性,
所以访问时,应该用.(点)来层层访问:LangShen.Name、LangShen.AGE,当然我们也可以用数组的方式来访问,如:LangShen["Name"]、LangShen["AGE"],结果是一样的。
该写法,在JSON数据结构中经常用,除此之外,我们平时写函数组的时候,也经常用到,如:

复制代码




var LangShen = { 
   
Name = function(){ 
   
return "LangShen"; 
   
}, 
   
Age = function(){ 
   
return "28"; 
   
} 
   
}

调用方式差不多,因为是函数组,所以要加上(),如:alert( LangShen.Name() );


二、[ ]中括号,表示一个数组,也可以理解为一个数组对象。


如:var LangShen = [ "Name","LangShen","AGE","28" ];


很明显,每个值或函数,都是独立的,多个值之间只用,(逗号)隔开,因为是数组对象,所以它等于:


var LangShen = Array( "Name","LangShen","AGE","28" );


访问时,也是和数组一样,alert( LangShen[0] );


三、{ } 和[ ] 一起使用,我们前面说到,{ } 是一个对象,[ ] 是一个数组,我们可以组成一个对象数组,如:


复制代码




var LangShen = { "Name":"Langshen", 
   
"MyWife":[ "LuLu","26" ], 
   
"MySon":[{"Name":"Son1"},{"Name":"Son2"},{"Name":"Son3"}] 
   
}


从上面的结构来看,是一个对象里面的第一项是个属性,第二项是一个数组,第三个是包含有多个对象的数组。调用起来,也是一层一层访问,对象的属性用.(点)叠加,数组用 [下标] 来访问。


如:alert( LangShen.MySon[1].Name ) ; <!--NEWSZW_HZH_END-->


您可能感兴趣的文章:

解析Javascript中大括号“{}”的多义性

 



增加 减小] 类型:转载



<!--end art_info-->



 



 



这篇文章主要介绍了Javascript中大括号“{}”的多义性。需要的朋友可以过来参考下,希望对大家有所帮助



 



 



 



 



 



JS中大括号有四种语义作用

语义1,组织复合语句,这是最常见的



复制代码



if( condition ) { 
     
 //... 
     
}else { 
     
 //... 
     
} 
     
for() { 
     
 //... 
     
}


语义2,对象直接量声明


复制代码


var obj = { 
     
 name : 'jack', 
     
 age : 23 
     
};


整个是个赋值语句,其中的{name:'jack',age:23}是个表达式。


 

语义3,声明函数或函数直接量



复制代码



function f1(){ 
     
 //... 
     
} 
     

var f2 = function(){ 
     
 //... 
     
}



f1与非f2的区别是前者在语法解释期,后者在运行期。区别在于:如果调用该函数的代码在函数定义之后,则没有区别;如果调用该函数的代码在函数定义之前,则f1仍然可以调用,f2则会报错,提示f2未定义。


 

语义4,结构化异常处理的语法符号



复制代码



try { 
     
 //... 
     
}catch( ex ){ 
     
 //... 
     
}finally{ 
     
 //... 
     
}

这里的大括号与符合语句(语义1 )是有区别的,大括号中如果只有一条语句,在if/else/for等中大括号是可以省略的,但try/catch/finally则不能省略。


 

以下代码纠结了偶N久



复制代码




function(){}() //匿名函数立即执行, 语法分析期报 
     
{}.constructor //获取对象直接量的构造器,语法分析期报错


令人不解的是为何[].constructor这么写却不报错呢,一个是想获取对象直接量的构造器,一个是获取数组直接量的构造器而已。


 

当然添加个变量接收也不会报错

var c = {}.constructor;

同样的情况如

var fn = function(){}(),也不会报错。

实际上是js的“语句优先”在作怪,即{}被理解成复合语句块(语义1 )而不是对象直接量(语义2 )或声明函数(语义3 )的语义。

function(){}(),大括号被理解成复合语句,自然前面的function()声明函数的语法不完整导致语法分析期出错。

{}.constructor,大括号被理解成复合语句,大括号后面是点运算符,点运算符前没有合理的对象自然也报错。

修复方式众所周知:加个强制运算符()(function(){})(),(function(){});//强制其理解为函数(语义3 ),“函数()”表示执行该函数,即声明后立即执行了。

({}).constructor //({})强制把大括号理解成对象直接量(语义2 ),“对象.xx”表示获取对象的成员,自然后面的点运算符可以正常执行了。