自动分号插入
尽管 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
表达式,也不应该省略花括号。
这些良好的编程习惯不仅可以提到代码的一致性,而且可以防止解析器改变代码行为的错误处理。
分享到:
相关推荐
在“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解析器会在某些语句后自动插入分号,但这并不总能按预期工作,因此在编写代码时应明确添加分号。 #### 结论 `JavaScript_Garden_CN`不仅是一份学习资料,更是一扇通往JavaScript...
JavaScript应用实例-自动回复.js
es5 标准定义了自动分号插入规则,包括以下三个基本规则加两个前置条件: 前置条件 1、如果插入分号后解析结果是空语句,那么不会自动插入分号。 例子:(空语句,else 前不加分好) if (a > b) else c = d 2
目前仅有的讲JavaScript的测试驱动开发的书,英文版,Amazon书评4星级的好书。
JavaScript应用实例-自动发红包.js
JavaScript 教程--从入门到精通(PPT 精简版) 本节课程为初学者提供了 JavaScript 的基本概念、特点、优点和编程技术,旨在帮助学习者快速掌握 JavaScript 的基础知识和编程技能。 一、JavaScript 概述 JavaScript...
JavaScript应用实例-自动上传视频UI.js
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
《深入解析org.mozilla.javascript-1.7.2.jar》 在Java开发中,JavaScript引擎的使用日益广泛,其中Mozilla的Rhino引擎是备受开发者青睐的一款。本文将围绕"org.mozilla.javascript-1.7.2.jar"这个资源包,详细讲解...
JavaScript应用实例-自动加群免验证好友V1.6(修复部分bug).js
JavaScript,作为一种广泛应用于Web开发的脚本语言,是由Netscape公司为了增强浏览器与用户之间的交互而创造的。它的出现打破了HTML只能展示静态信息的局限,使得网页具备了实时、动态和交互的能力。JavaScript并不...
开发者可以轻松地在HTML文档中插入JavaScript代码,从而实现对网页元素的控制。 **2. 基于对象的语言** JavaScript虽然没有严格的类定义,但可以通过对象的方式来实现面向对象的编程。例如,可以通过构造函数或ES6...
基于JavaScript+CSS的地图插件-文章中插入交互式地图(支持GoogleMap、高德地图、百度地图、Geoq地图和 OpenStreetMap).zip 文章中插入交互式地图。它支持多种地图类型,包括 GoogleMap、高德地图、百度地图、Geoq...
第15周-第21章节-Python3.5-javascript必须加分号.avi
这份文档包含了深入的技术细节,对于希望利用JavaScript增强Photoshop功能、自动化工作流程或开发定制插件的开发者来说,是不可或缺的资源。 ### Photoshop CS6 JavaScript脚本编程 在Photoshop CS6中,JavaScript...