自动分号插入
尽管 JavaScript 有 C 的代码风格,但是它不强制要求在代码中使用分号,实际上可以省略它们。
JavaScript 不是一个没有分号的语言,恰恰相反上它需要分号来就解析源代码。
因此 JavaScript 解析器在遇到由于缺少分号导致的解析错误时,会自动在源代码中插入分号。
var foo = function() {
} // 解析错误,分号丢失
test()
自动插入分号,解析器重新解析。
var foo = function() {
}; // 没有错误,解析继续
test()
自动的分号插入被认为是 JavaScript 语言最大的设计缺陷之一,因为它能改变代码的行为。
工作原理
下面的代码没有分号,因此解析器需要自己判断需要在哪些地方插入分号。
(function(window, undefined) {
function test(options) {
log('testing!')
(options.list || []).forEach(function(i) {
})
options.value.test(
'long string to pass here',
'and another long string to pass'
)
return
{
foo: function() {}
}
}
window.test = test
})(window)
(function(window) {
window.someLibrary = {}
})(window)
下面是解析器"猜测"的结果。
(function(window, undefined) {
function test(options) {
// 没有插入分号,两行被合并为一行
log('testing!')(options.list || []).forEach(function(i) {
}); // <- 插入分号
options.value.test(
'long string to pass here',
'and another long string to pass'
); // <- 插入分号
return; // <- 插入分号, 改变了 return 表达式的行为
{ // 作为一个代码段处理
foo: function() {}
}; // <- 插入分号
}
window.test = test; // <- 插入分号
// 两行又被合并了
})(window)(function(window) {
window.someLibrary = {}; // <- 插入分号
})(window); //<- 插入分号
注意: JavaScript 不能正确的处理 return
表达式紧跟换行符的情况,
虽然这不能算是自动分号插入的错误,但这确实是一种不希望的副作用。
解析器显著改变了上面代码的行为,在另外一些情况下也会做出错误的处理。
前置括号
在前置括号的情况下,解析器不会自动插入分号。
log('testing!')
(options.list || []).forEach(function(i) {})
上面代码被解析器转换为一行。
log('testing!')(options.list || []).forEach(function(i) {})
log
函数的执行结果极大可能不是函数;这种情况下就会出现 TypeError
的错误,详细错误信息可能是 undefined is not a function
。
结论
建议绝对不要省略分号,同时也提倡将花括号和相应的表达式放在一行,
对于只有一行代码的 if
或者 else
表达式,也不应该省略花括号。
这些良好的编程习惯不仅可以提到代码的一致性,而且可以防止解析器改变代码行为的错误处理。
分享到:
相关推荐
JavaScript_数组方法-删除、插入、替换.源码
在“photoshop-cc-javascript-ref-2015.pdf”中,你将找到详细的API参考,每个函数和对象的说明,以及示例代码,帮助你理解和掌握如何在实际项目中运用JavaScript。同时,该文档通常会包含错误处理和最佳实践的建议...
JavaScript教程--从入门到精通(PPT精简版).ppt
LoadMod ( 'https://rawgit.com/yannprada/cookie-garden-helper/master/cookie-garden-helper.js' ) ; } ( ) ) ; 这个怎么运作 首先,点击花园/农场底部的“ Cookie Garden Helper ”按钮。 在这里,您可以配置您...
本资源“javascript经典特效---javascript代码自动生成.rar”显然聚焦于如何利用JavaScript生成代码,以创建出吸引人的视觉特效。这个压缩包内包含了一个名为“javascript代码自动生成.htm”的文件,很可能是教程或...
在JavaScript编程中,自动分号插入(Automatic Semicolon Insertion,ASI)是一个重要的语法规则。理解这一机制对于编写符合ECMAScript标准的代码至关重要。下面将围绕这个话题详细探讨相关的知识点。 首先,...
在输入框中自动提示文本。 HTMLAPP-网页设计作业-前端作业-JavaScript作业-大学生作业-计算机课程 htmlapp书上的作业 直接打开html就可以 项目包里面有作业:上传文件 ;为视频播放器设置截图功能 ;验证表格是否为...
- **自动分号插入**: JavaScript解析器会在某些语句后自动插入分号,但这并不总能按预期工作,因此在编写代码时应明确添加分号。 #### 结论 `JavaScript_Garden_CN`不仅是一份学习资料,更是一扇通往JavaScript...
JavaScript应用实例-自动回复.js
es5 标准定义了自动分号插入规则,包括以下三个基本规则加两个前置条件: 前置条件 1、如果插入分号后解析结果是空语句,那么不会自动插入分号。 例子:(空语句,else 前不加分好) if (a > b) else c = d 2
目前仅有的讲JavaScript的测试驱动开发的书,英文版,Amazon书评4星级的好书。
JavaScript应用实例-自动发红包.js
JavaScript应用实例-自动上传视频UI.js
《深入解析org.mozilla.javascript-1.7.2.jar》 在Java开发中,JavaScript引擎的使用日益广泛,其中Mozilla的Rhino引擎是备受开发者青睐的一款。本文将围绕"org.mozilla.javascript-1.7.2.jar"这个资源包,详细讲解...
JavaScript应用实例-自动上传视频主文件.js
该项目是一款基于HTML、JavaScript和CSS开发的智慧园林设计应用程序源码,包含332个文件,其中包括134个HTML文件、115个PNG图片文件、39个JavaScript文件、18个CSS文件、5个XML文件、4个DS_Store文件、4个JPG文件、3...
### 廖雪峰-JavaScript教程-PDF版 #### JavaScript的重要性及发展历程 JavaScript作为世界上最流行的脚本语言之一,在Web开发领域占据着举足轻重的地位。无论是个人开发者还是大型企业,都离不开JavaScript的支持...
JavaScript应用实例-自动发红包(2).js
自动分号插入(Automatic Semicolon Insertion, ASI)是ECMAScript规范定义的一种机制,用于在合适的位置自动插入分号。这种机制的存在使得JavaScript程序员可以自由选择是否添加分号。 **2. 插入规则** 按照ECMA-...