自动分号插入
尽管 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。同时,该文档通常会包含错误处理和最佳实践的建议...
LoadMod ( 'https://rawgit.com/yannprada/cookie-garden-helper/master/cookie-garden-helper.js' ) ; } ( ) ) ; 这个怎么运作 首先,点击花园/农场底部的“ Cookie Garden Helper ”按钮。 在这里,您可以配置您...
在JavaScript编程中,自动分号插入(Automatic Semicolon Insertion,ASI)是一个重要的语法规则。理解这一机制对于编写符合ECMAScript标准的代码至关重要。下面将围绕这个话题详细探讨相关的知识点。 首先,...
### JavaScript Garden:深入探讨JavaScript中的陷阱与注意事项 #### 引言 《JavaScript Garden》是一份不断更新、详尽记录了JavaScript编程语言中最易犯错误、陷阱及细微问题的指南。该文档不仅帮助开发者规避常见...
- **自动分号插入**: JavaScript解析器会在某些语句后自动插入分号,但这并不总能按预期工作,因此在编写代码时应明确添加分号。 #### 结论 `JavaScript_Garden_CN`不仅是一份学习资料,更是一扇通往JavaScript...
es5 标准定义了自动分号插入规则,包括以下三个基本规则加两个前置条件: 前置条件 1、如果插入分号后解析结果是空语句,那么不会自动插入分号。 例子:(空语句,else 前不加分好) if (a > b) else c = d 2
JavaScript 教程--从入门到精通(PPT 精简版) 本节课程为初学者提供了 JavaScript 的基本概念、特点、优点和编程技术,旨在帮助学习者快速掌握 JavaScript 的基础知识和编程技能。 一、JavaScript 概述 JavaScript...
JavaScript应用实例-自动上传视频主文件.js
JavaScript中的分号插入机制是一种特殊的语法特性,它允许开发者在编写代码时不强制要求在语句末尾显式地写上分号(;),而是在某些情况下由JavaScript引擎自动插入。这种机制的存在可以使得代码更加简洁,但同时也...
### 廖雪峰-JavaScript教程-PDF版 #### JavaScript的重要性及发展历程 JavaScript作为世界上最流行的脚本语言之一,在Web开发领域占据着举足轻重的地位。无论是个人开发者还是大型企业,都离不开JavaScript的支持...
《深入解析org.mozilla.javascript-1.7.2.jar》 在Java开发中,JavaScript引擎的使用日益广泛,其中Mozilla的Rhino引擎是备受开发者青睐的一款。本文将围绕"org.mozilla.javascript-1.7.2.jar"这个资源包,详细讲解...
JavaScript应用实例-自动发红包(2).js
自动分号插入(Automatic Semicolon Insertion, ASI)是ECMAScript规范定义的一种机制,用于在合适的位置自动插入分号。这种机制的存在使得JavaScript程序员可以自由选择是否添加分号。 **2. 插入规则** 按照ECMA-...
javascript使用JWT令牌安全登录,登录信息存在于token里。获取到token需要一个解析过程,从而获取到user role之类的信息。这就是个前台解token的案例 PS.最近积分自动上浮了??
And you’ll learn how to capitalize on trends like server-side JavaScript and NoSQL data stores, as well as new frameworks that make JavaScript more manageable and testable as a first-class language....
开发者可以轻松地在HTML文档中插入JavaScript代码,从而实现对网页元素的控制。 **2. 基于对象的语言** JavaScript虽然没有严格的类定义,但可以通过对象的方式来实现面向对象的编程。例如,可以通过构造函数或ES6...
总结起来,JavaScript入门学习应从理解其重要性、易学性开始,接着熟悉在HTML中插入和引用JavaScript代码的方法,掌握基础语法,包括语句的使用和分号的规范,以及了解注释的运用。通过这些基础知识,初学者可以逐步...
JavaScript是一种广泛应用于Web开发的轻量级...通过理解JavaScript的基础语法、DOM操作、代码插入方式、位置选择以及注释的使用,初学者可以逐步构建自己的JavaScript知识体系,为进一步深入学习和开发奠定坚实的基础。