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

摘要:本文主要介绍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表示获取对象的成员,自然后面的点运算符可以正常执行了。

作者: snandy  原文链接

时间: 2024-08-24 22:32:43

Javascript中大括号“{}”的多义性的相关文章

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

JS中大括号有四种语义作用 语义1,组织复合语句,这是最常见的 复制代码 代码如下: if( condition ) {   //... }else {   //... } for() {   //... } 语义2,对象直接量声明 复制代码 代码如下: var obj = {     name : 'jack',     age : 23 }; 整个是个赋值语句,其中的{name:'jack',age:23}是个表达式. 语义3,声明函数或函数直接量 复制代码 代码如下: function f

Javascript小括号“()”的多义性

摘要:本文主要介绍JavaScript中小括号有五种语义. Javascript中小括号有五种语义 语义1,函数声明时参数表 function func(arg1,arg2){ // ... } 语义2,和一些语句联合使用以达到某些限定作用 // 和for in一起使用 for(var a in obj){ // ... } // 和if一起使用 if(boo){ //... } // 和while一起使用 while(boo){ // ... } // 和do while一起使用 do{ //

Javascript 中的小括号 “()” 的多义性

Javascript 中小括号有5 种语义 语义1:函数声明时参数表 1 function func(arg1, arg2){  2    // ...  3  }    语义2:和一些语句联合使用以达到某些限定作用 1 // 和 for in 一起使用   2 for(var a in obj){   3   // ...   4 }   5    6 // 和 if 一起使用   7 if(boo){   8   //...   9 }  10   11 // 和 while 一起使用  1

[转] Javascript 中的小括号 “()” 的多义性

Javascript 中小括号有5 种语义 语义1:函数声明时参数表 1 function func(arg1, arg2){ 2 // ... 3 } 语义2:和一些语句联合使用以达到某些限定作用 1 // 和 for in 一起使用 2 for(var a in obj){ 3 // ... 4 } 5 6 // 和 if 一起使用 7 if(boo){ 8 //... 9 } 10 11 // 和 while 一起使用 12 while(boo){ 13 // ... 14 } 15 16

php中大括号作用{}

1.将多个独立语句合并为一个复合语句,例如 if ... else ...中经常如此使用 2.在变量间接引用中进行定界,避免歧义.例如 ${$my_var[8]}与${$my_var}[8]的区分 3.用于指示字符串变量中的单个字符(下标从0开始),例如 $my_str="1234"; $my_str{1}='5'; //现在 $my_str 内容为 '1534' 此用法为PHP 5之后的特性,用于消除使用中括号引起的歧义. 4,界定变量的名称 $var='sky'; echo &qu

javascript小括号、中括号、大括号学习总结

作为一名编程人员,和括号打交道是必不可少的.你可知道在不同的上下文中,括号的作用是不一样的,今天就让我们简单总结下javascript小括号.中括号.大括号的用法. 总的来说,JavaScript中小括号有五种语义,中括号有四种语义,而大括号也有四种语义. 小括号: 语义1,函数声明时参数表(形参) 语义2,和一些语句联合使用以达到某些限定作用(if.for等) 语义3,和new一起使用用来传值(实参) 语义4,作为函数或对象方法的调用运算符(如果定义了参数也可与语义3一样传实参) 语义5,强制

JavaScript中function的多义性

JavaScript 中的 function 有多重意义.它可能是一个构造器(constructor),承担起对象模板的作用: 可能是对象的方法(method),负责向对象发送消息.还可能是函数,没错是函数,和对象没有任何关系独立存在的可以被调用的函数. 由于语言设计者的妥协,在 JavaScript 加入了一些 class 相关的特性,以使 JavaScript 看起来确实象 Java,可以 “面向对象”.虽然 JavaScript 添加了 new 和 this, 但却没有 class (ES

算法题:括号匹配(小中大括号序列)

括号序列由( )[ ]{ }组成,不合法的括号序列由( { ) },[ } { ],等等.编程实现一个函数,检查一个括号序列是否是合法的括号序列. 解法: 思路和"后缀表达式的求解"相似.我们借助栈,每读一个括号,如果是左括号,那么入栈,然后继续读下一个括号:如果是右括号,那么就要看看这个右括号和栈顶的括号是否匹配:如果匹配,那么弹出栈顶的括号,继续读下一个括号.当栈变空时,说明此括号序列是合法的. public class Test05 { public static boolean

shell脚本中大括号的扩展在变量中的问题

[email protected]:/tmp/test# touch /tmp/test/{2,3} [email protected]:/tmp/test# ls 2  3 [email protected]:/tmp/test# rm /tmp/test/{2,3} [email protected]:/tmp/test# ls [email protected]:/tmp/test# t={2,3} [email protected]:/tmp/test# touch /tmp/test/