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


Posted in Javascript onDecember 02, 2013

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”表示获取对象的成员,自然后面的点运算符可以正常执行了。

Javascript 相关文章推荐
js中的前绑定和后绑定详解
Aug 01 Javascript
使用js实现的简单拖拽效果
Mar 18 Javascript
Jquery 垂直多级手风琴菜单附源码下载
Nov 17 Javascript
jQuery内容过滤选择器用法示例
Sep 09 Javascript
jQuery弹出层插件popShow(改进版)用法示例
Jan 23 Javascript
underscore之function_动力节点Java学院整理
Jul 11 Javascript
微信页面弹出键盘后iframe内容变空白的解决方案
Sep 20 Javascript
javascript实现最长公共子序列实例代码
Feb 05 Javascript
基于webpack-hot-middleware热加载相关错误的解决方法
Feb 22 Javascript
微信小程序模板消息推送的两种实现方式
Aug 27 Javascript
layui中的switch开关实现方法
Sep 03 Javascript
使用JavaScript通过前端发送电子邮件
May 22 Javascript
解析JavaScript中点号“.”的多义性
Dec 02 #Javascript
解析JavaScript中的不可见数据类型
Dec 02 #Javascript
Jquery使用Firefox FireBug插件调试Ajax步骤讲解
Dec 02 #Javascript
jquery遍历之parent()和parents()的区别及parentsUntil()方法详解
Dec 02 #Javascript
jQuery向上遍历DOM树之parents(),parent(),closest()之间的区别
Dec 02 #Javascript
javascript中对Attr(dom中属性)的操作示例讲解
Dec 02 #Javascript
浅析jquery的作用与优势
Dec 02 #Javascript
You might like
php中字符串和正则表达式详解
2014/10/23 PHP
PHP实现的蚂蚁爬杆路径算法代码
2015/12/03 PHP
关于PHP转换超过2038年日期出错的问题解决
2017/06/28 PHP
PHP获取数据库表中的数据插入新的表再原删除数据方法
2018/10/12 PHP
js下弹出窗口的变通
2007/04/18 Javascript
AngularJS ng-bind-template 指令详解
2016/07/30 Javascript
JS实现字符串转驼峰格式的方法
2016/12/16 Javascript
Javascript网页抢红包外挂实现分享
2018/01/11 Javascript
解决在vue项目中,发版之后,背景图片报错,路径不对的问题
2018/03/06 Javascript
在Mac下彻底卸载node和npm的方法
2018/05/16 Javascript
express框架下使用session的方法
2019/07/31 Javascript
浅谈layer弹出层按钮颜色修改方法
2019/09/11 Javascript
vue限制输入框只能输入8位整数和2位小数的代码
2019/11/06 Javascript
在Vue中使用Viser说明(基于AntV-G2可视化引擎)
2020/10/28 Javascript
JS使用setInterval计时器实现挑战10秒
2020/11/08 Javascript
vue+element table表格实现动态列筛选的示例代码
2021/01/14 Vue.js
[02:40]2014DOTA2 国际邀请赛中国区预选赛 四大豪门抵达华西村
2014/05/23 DOTA
利用Psyco提升Python运行速度
2014/12/24 Python
使用py2exe在Windows下将Python程序转为exe文件
2016/03/04 Python
Python实现简易端口扫描器代码实例
2017/03/15 Python
Python存取XML的常见方法实例分析
2017/03/21 Python
python技能之数据导出excel的实例代码
2017/08/11 Python
Python计算斗牛游戏概率算法实例分析
2017/09/26 Python
python游戏地图最短路径求解
2019/01/16 Python
浅谈python3.6的tkinter运行问题
2019/02/22 Python
Python3多线程版TCP端口扫描器
2019/08/31 Python
python数据处理——对pandas进行数据变频或插值实例
2020/04/22 Python
Python configparser模块常用方法解析
2020/05/22 Python
世界上最大的隐形眼镜商店:1-800 Contacts
2018/11/03 全球购物
馥蕾诗美国官网:Fresh美国
2019/10/09 全球购物
电子商务专业实习生自我鉴定
2013/09/24 职场文书
横幅标语大全
2014/06/17 职场文书
小学生九一八纪念日83周年演讲稿500字
2014/09/17 职场文书
2014年挂职干部工作总结
2014/12/06 职场文书
启迪人心的励志语录:脾气永远不要大于本事
2020/01/02 职场文书
一条 SQL 语句执行过程
2022/03/17 MySQL