`

JavaScript Garden -自动分号插入

阅读更多

自动分号插入

尽管 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 表达式,也不应该省略花括号。
这些良好的编程习惯不仅可以提到代码的一致性,而且可以防止解析器改变代码行为的错误处理。

2
1
分享到:
评论

相关推荐

    JavaScript-数组方法-删除、插入、替换.源码

    JavaScript_数组方法-删除、插入、替换.源码

    photoshop-cc-javascript-ref-2015.pdf

    在“photoshop-cc-javascript-ref-2015.pdf”中,你将找到详细的API参考,每个函数和对象的说明,以及示例代码,帮助你理解和掌握如何在实际项目中运用JavaScript。同时,该文档通常会包含错误处理和最佳实践的建议...

    cookie-garden-helper:在游戏中使您的花园自动化Cookie Clicker

    LoadMod ( 'https://rawgit.com/yannprada/cookie-garden-helper/master/cookie-garden-helper.js' ) ; } ( ) ) ; 这个怎么运作 首先,点击花园/农场底部的“ Cookie Garden Helper ”按钮。 在这里,您可以配置您...

    JavaScript 自动分号插入(JavaScript synat:auto semicolon insertion)

    在JavaScript编程中,自动分号插入(Automatic Semicolon Insertion,ASI)是一个重要的语法规则。理解这一机制对于编写符合ECMAScript标准的代码至关重要。下面将围绕这个话题详细探讨相关的知识点。 首先,...

    javascript garden

    ### JavaScript Garden:深入探讨JavaScript中的陷阱与注意事项 #### 引言 《JavaScript Garden》是一份不断更新、详尽记录了JavaScript编程语言中最易犯错误、陷阱及细微问题的指南。该文档不仅帮助开发者规避常见...

    JavaScript_Garden_CN

    - **自动分号插入**: JavaScript解析器会在某些语句后自动插入分号,但这并不总能按预期工作,因此在编写代码时应明确添加分号。 #### 结论 `JavaScript_Garden_CN`不仅是一份学习资料,更是一扇通往JavaScript...

    浅析Javascript的自动分号插入(ASI)机制

    es5 标准定义了自动分号插入规则,包括以下三个基本规则加两个前置条件: 前置条件 1、如果插入分号后解析结果是空语句,那么不会自动插入分号。 例子:(空语句,else 前不加分好) if (a &gt; b) else c = d 2

    JavaScript教程--从入门到精通(PPT精简版)

    JavaScript 教程--从入门到精通(PPT 精简版) 本节课程为初学者提供了 JavaScript 的基本概念、特点、优点和编程技术,旨在帮助学习者快速掌握 JavaScript 的基础知识和编程技能。 一、JavaScript 概述 JavaScript...

    JavaScript应用实例-自动上传视频主文件.js

    JavaScript应用实例-自动上传视频主文件.js

    JavaScript中的分号插入机制详细介绍

    JavaScript中的分号插入机制是一种特殊的语法特性,它允许开发者在编写代码时不强制要求在语句末尾显式地写上分号(;),而是在某些情况下由JavaScript引擎自动插入。这种机制的存在可以使得代码更加简洁,但同时也...

    廖雪峰-JavaScript教程-PDF版

    ### 廖雪峰-JavaScript教程-PDF版 #### JavaScript的重要性及发展历程 JavaScript作为世界上最流行的脚本语言之一,在Web开发领域占据着举足轻重的地位。无论是个人开发者还是大型企业,都离不开JavaScript的支持...

    org.mozilla.javascript-1.7.2.jar

    《深入解析org.mozilla.javascript-1.7.2.jar》 在Java开发中,JavaScript引擎的使用日益广泛,其中Mozilla的Rhino引擎是备受开发者青睐的一款。本文将围绕"org.mozilla.javascript-1.7.2.jar"这个资源包,详细讲解...

    JavaScript应用实例-自动发红包(2).js

    JavaScript应用实例-自动发红包(2).js

    【JavaScript源代码】JavaScript中分号的一些细节.docx

    自动分号插入(Automatic Semicolon Insertion, ASI)是ECMAScript规范定义的一种机制,用于在合适的位置自动插入分号。这种机制的存在使得JavaScript程序员可以自由选择是否添加分号。 **2. 插入规则** 按照ECMA-...

    javascript -jwt-decode.zip

    javascript使用JWT令牌安全登录,登录信息存在于token里。获取到token需要一个解析过程,从而获取到user role之类的信息。这就是个前台解token的案例 PS.最近积分自动上浮了??

    Single Page Web Applications JavaScript end-to-end

    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....

    Javascript教程--从入门到精通【完整版】

    开发者可以轻松地在HTML文档中插入JavaScript代码,从而实现对网页元素的控制。 **2. 基于对象的语言** JavaScript虽然没有严格的类定义,但可以通过对象的方式来实现面向对象的编程。例如,可以通过构造函数或ES6...

    JavaScript入门-教案1.pdf

    总结起来,JavaScript入门学习应从理解其重要性、易学性开始,接着熟悉在HTML中插入和引用JavaScript代码的方法,掌握基础语法,包括语句的使用和分号的规范,以及了解注释的运用。通过这些基础知识,初学者可以逐步...

    JavaScript入门-教案1.docx

    JavaScript是一种广泛应用于Web开发的轻量级...通过理解JavaScript的基础语法、DOM操作、代码插入方式、位置选择以及注释的使用,初学者可以逐步构建自己的JavaScript知识体系,为进一步深入学习和开发奠定坚实的基础。

Global site tag (gtag.js) - Google Analytics