JS的分號可以省掉嗎?

来源:https://www.cnblogs.com/fundebug/archive/2018/09/18/js_semicolon_bug.html
-Advertisement-
Play Games

JavaScript語言從設計之初就是考慮帶分號的,使用不帶分號的編碼規則就要小心點啦。 ...


摘要: JavaScript語言從設計之初就是考慮帶分號的,使用不帶分號的編碼規則就要小心點啦。

背景

最近在項目中開始使用新的編碼規範,一開始ESLint報一大堆錯誤,改得我想砸鍵盤,花了好些時間才適應,下麵列出一些代表性的規則:

  • 只能使用單引號
  • 函數定義的圓括弧和左大括弧之間一定要有空格: function(args) { .. }
  • import語句在大括弧之後一定要有空格: import { fa, fb } from moduleC
  • 不用分號!!!

起因

早上在實現一個功能的時候,寫了一個map函數來複用部分代碼。程式運行起來後,沒有執行結果,而且沒有報錯。通過console.log列印數據發現,整個程式執行到map前面就再也不往下走了,很奇怪。因為沒有報錯信息,無法推測具體原因。於是,我將其抽象成非常簡單的代碼來排查。如下所示:

console.log("hello, fundebug")
[1, 2, 3].map(i=>console.log(i))

然後執行看看結果如何:

在項目中沒有報錯,單獨將這段代碼拿出來在瀏覽器控制臺下執行卻報錯了!
這麼簡單的代碼為什麼會出錯呢?第一反應就是JS引擎將代碼生成語法樹的時候,可能解析不正確。於是,我在第一行末尾加分號測試。

console.log("hello, fundebug");
[1, 2, 3].map(i=>console.log(i))

程式正確執行了:

這讓我更加犯難,如果不加分號會導致程式出錯,那麼為什麼還會推崇這樣的編碼規範呢?
在網路上搜索JavaScript關於分號的BUG,發現有非常多關於要不要使用分號的討論。

大宗師Douglas Crockford表示要正確使用分號

引用minhan在扯不完的 JS 分號問題文中的論述:

JSON、JSLint、JSMin和ADSafe 的創造者、ECMA JavaScript 2.0 標準化委員會委員、被JavaScript之父Brendan Eich稱為JavaScript的大宗師、名著《JavaScript: The Good Parts》(中文版《JavaScript語言精粹》)的作者Douglas Crockford直接懟之: 這代碼真尼瑪的瘋狂傻X,我是不會為了這傻X的案例而去降低JSMin的級數; TC39正在考慮將『!』號作為中綴運算符使用,這個代碼不久將來就運行不了。趕緊修複吧,學學怎麼正確地使用分號。『!』號並不語句的分隔號,『;』才是。

JSMin處理如下代碼後無法正確執行:

clearMenus()
!isActive && $parent.toggleClass('open')

自動分號插入機制

JavaScript有著自動分號插入的機制(Automatic Semicolon Insertion),簡稱ASI。這是一個輔助性的功能,然後有一些情況要註意:

如果你這樣寫代碼:

return 
a + b

那麼自動分號插入後會這樣:

return;
a + b;

更可能導致隱含BUG的狀況是:

a = b + c
(d + e).print()

他不會自動插入分號,因為第二行一括弧開始,會被誤認為是函數。

a = b + c(d + e).print();

所以,我剛剛的的代碼在自動插入分號後,應該是這樣:

console.log("hello fundebug")[1,2,3].map(i=>console.log(i))

那麼這樣看來,用分號才是最安全的做法咯!

如果你不想用分號,又怕出問題,v2ex上有位童鞋給出了一個速記方案

如果你寫 JS 代碼不喜歡帶分號,而又搞不清什麼時候必須加分號,可以這麼做:在以 "("、"[" 、"/"、"+"、"-" 開頭的語句前面都加上一個分號。

我最終的解法是先聲明一個變數來指向這個數組,這樣就可以避免以[開頭,又不使用分號:

let indexArray = [1, 2, 3]
indexArray.map(i=>console.log(i))

關於Fundebug

Fundebug專註於JavaScript、微信小程式、微信小游戲、支付寶小程式、React Native、Node.js和Java實時BUG監控。 自從2016年雙十一正式上線,Fundebug累計處理了6億+錯誤事件,得到了Google、360、金山軟體等眾多知名用戶的認可。歡迎免費試用!

轉載時請註明作者 Fundebug以及本文地址:
https://blog.fundebug.com/ 2018/09/18/js-semicolon-bug/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 學習後的總結: DOM:document object model 關於DOM的簡介:http://www.w3school.com.cn/htmldom/dom_intro.asp 本文說的是HTML DOM 的一些操作: DOM樹:DOM樹將HTML文檔體現為樹狀,DOM樹中有很多節點; DOM ...
  • web開發中經常會有這種情況,在一個主頁面中包含側邊導航菜單和iframe,點擊菜單項,對應頁面會在iframe中顯示,整個頁面不會刷新。但是如果設置了會話Session,在會話過期後再操作會自動redirect重定向到登錄頁面,經常會出現在session過期後,再點擊菜單項,登錄頁面顯示在ifra ...
  • h5界面嵌套在原生app內部的時候,需要調用原生的方法,傳遞數據。中間難以調試代碼,。 用google的 inspect調試。查看數據的傳輸方式。 1、adb連接正常,打開手機USB調試 2、第一次使用的時候一定要保證翻牆!翻牆!翻牆 (不懂的可以問我) 3、谷歌瀏覽器中打開chrome://ins ...
  • 我們知道,js函數有多種寫法,函數聲明 ,函數表達式,Function式構造函數,自執行函數,包括Es6的箭頭函數,Class類寫法,高階函數,函數節流/函數防抖,下麵我就開始講關於上面幾種類型的最基本用法。 函數聲明式寫法 這種寫法是最基本的寫法 ,使用關鍵字 function 定義函數,函數聲明 ...
  • 半年前跳槽, 新公司主要研發傾向於小程式的開發。由於之前並沒有接觸小程式,所以經過半年的實際開發,才敢來做一點筆記。 小程式提供很多組件給開發者使用,但是,實際使用中還是會有很多的問題。 老生常談的不能使用npm開發??? (雖然,已知的很多小程式框架可以實現。例如:mpvue等。但是讓我們先討論討 ...
  • 在 JavaScript 中正確使用地使用 Array 的方法如下: 用 Array.includes 代替 Array.indexOf “如果你要在數組中查找元素,請使用 Array.indexOf”。 MDN 文檔寫道,Array.indexOf 將“返回第一次出現給定元素的索引”。因此,如果我 ...
  • 今天是我們介紹數組系列文章的第五篇,也是我們數組系列的最後一篇文章,只是數據系列的結束,所以大家不用擔心,我們會持續的更新乾貨文章。 生命不息,更新不止! 今天我們就不那麼多廢話了,直接乾貨開始。 我們在《Javascript數組系列一之棧與隊列》中描述我們是如何利用 push、pop、shift、 ...
  • 什麼是斷點操作(Breakpoint action) 做前端開發的小伙伴,或許對這個斷點操作不是很熟悉。不過你要是問其他語言(比如C,C++ ,C #等)的開發者,他們應該都挺熟悉斷點操作,這種斷點操作在諸如XCode或者Visual Studio的IDE中都會有提供。 以下一段話來自知乎 斷點操作 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...