解析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 相关文章推荐
删除select中所有option选项jquery代码
Aug 12 Javascript
javascript 闭包详解
Feb 15 Javascript
JavaScript数组前面插入元素的方法
Apr 06 Javascript
JavaScript淡入淡出渐变简单实例
Aug 06 Javascript
JS实现同一个网页布局滑动门和TAB选项卡实例
Sep 23 Javascript
浅谈$('div a') 与$('div>a')的区别
Jul 18 Javascript
一句jQuery代码实现返回顶部效果(简单实用)
Dec 28 Javascript
vue keep-alive 动态删除组件缓存的例子
Nov 04 Javascript
Vuex中实现数据状态查询与更改
Nov 08 Javascript
Vue组件通信入门之Provide和Inject机制
Dec 29 Javascript
vue实现给div绑定keyup的enter事件
Jul 31 Javascript
在vue中动态修改css其中一个属性值操作
Dec 07 Vue.js
解析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
新52大事件
2020/03/03 欧美动漫
php zlib压缩和解压缩swf文件的代码
2008/12/30 PHP
分享一个PHP数据流应用的简单例子
2012/06/01 PHP
PHP中的替代语法介绍
2015/01/09 PHP
php实现在服务器上创建目录的方法
2015/03/16 PHP
php的无刷新操作实现方法分析
2020/02/28 PHP
Javascript中Eval函数的使用说明
2008/10/11 Javascript
图片img的src不变让浏览器重新加载实现方法
2013/03/29 Javascript
javascript 用函数语句和表达式定义函数的区别详解
2014/01/06 Javascript
JS实现窗口加载时模拟鼠标移动的方法
2015/06/03 Javascript
jquery限定文本框只能输入数字(整数和小数)
2016/01/08 Javascript
详解jQuery的表单验证插件--Validation
2016/12/21 Javascript
js实现拖拽功能
2017/03/01 Javascript
Javascript中引用类型传递的知识点小结
2017/03/06 Javascript
BACKBONE.JS 简单入门范例
2017/10/17 Javascript
JavaScript实现带有子菜单和控件的slider轮播图效果
2017/11/01 Javascript
Promise.all中对于reject的处理方法
2018/08/01 Javascript
vue拖拽排序插件vuedraggable使用方法详解
2020/08/21 Javascript
Bootstrap实现前端登录页面带验证码功能完整示例
2020/03/26 Javascript
Python中类的继承代码实例
2014/10/28 Python
通过Python实现自动填写调查问卷
2017/09/06 Python
python使用KNN算法手写体识别
2018/02/01 Python
解决python 自动安装缺少模块的问题
2018/10/22 Python
pandas.DataFrame删除/选取含有特定数值的行或列实例
2018/11/07 Python
解决python2 绘图title,xlabel,ylabel出现中文乱码的问题
2019/01/29 Python
深入学习python多线程与GIL
2019/08/26 Python
Python3列表List入门知识附实例
2020/02/09 Python
python中线程和进程有何区别
2020/06/17 Python
anaconda安装pytorch1.7.1和torchvision0.8.2的方法(亲测可用)
2021/02/01 Python
推荐10个HTML5响应式框架
2016/02/25 HTML / CSS
土耳其玩具商店:Toyzz Shop
2019/08/02 全球购物
学生不参加考试检讨书
2015/02/19 职场文书
幼儿园辞职书
2015/02/26 职场文书
《秋思》教学反思
2016/02/23 职场文书
2019年入党思想汇报
2019/03/25 职场文书
导游词之唐山景点
2019/12/18 职场文书