iT邦幫忙

2018 iT 邦幫忙鐵人賽
DAY 12
3

何謂 ESLint ?

ESLint 支援 ES6 與 JSX 語法,具高度設定彈性與擴充性的檢查語法工具,可提供程式開發者在語法上的錯誤警告,此篇教學我所使用的是 Airbnb 的規範,簡單來說 ESLint 就是可以規範整個開發團隊中的 coding style。

eslintairbnb

事前準備

還沒安裝的朋友可以先去看以下連結的教學哦!

需要準備的工具有 Visual Studio Code 當然你也可以用你熟悉的開發環境例如 : Sublime TextAtomVimNotepad++ ......等。

教學

有安裝 yarn 的朋友也可以利用 yarn 來安裝順便練習看看~

1. 初始化node

 npm init -y

這邊會產出一個package.json,這個檔案專門管理node的各種套件

2. 安裝eslint與babel-eslint

 npm install eslint babel-eslint --save-dev

3. 使用 eslint-airbnb-base

這邊可以參考至 Airbnb 的GitHub

 npm install eslint-config-airbnb-base eslint-plugin-import eslint --save-dev

4. 建立 .eslintrc 檔案並貼上下列程式

{
  "parser": "babel-eslint", //parser: 指的是剖析器,如果你有用babel編譯器,就是設定"babel-eslint"
  "env": {
    "browser": true,
    "node": true
  },
  "extends": "airbnb-base",
  "rules": {
    "semi": [2, "never"],
    "arrow-body-style": ["error", "always"],
    "comma-dangle": ["error", "never"], //該規則強制使用對象和數組文字中的逗號
    "no-console": 0 //關掉console.log()錯誤
  }
}

5. 安裝擴充套件

接下來使用 Visual Studio Code 的看過來,請記得到擴充套件內下載 ESLint 的擴充套件才會即時顯示錯誤哦很重要!他主要是會去讀取你剛建立的 .eslintrc 檔案若沒安裝這個擴充套件也沒有用,原生系統不會去吃這隻檔案,若使用其他編輯器的使用者也可以到該應用程式下的擴充功能找下載基本上都會有支援像是 Sublime Text 以及 Atom 都能找到。

https://ithelp.ithome.com.tw/upload/images/20171222/20107247alrrCQuVLm.png

結果

最後你可以發現你的程式碼出現紅紅的底線囉!他代表你的程式碼不符合規範哦叫你馬上修正,你可以按下左邊燈泡點選 Fix all 它會一次幫你修正所有對問題,是不是很方便~此外最下面終端機中點選問題可以詳細知道所有的問題,例如要空白、結尾不能有分號、最後一行要換行......等,懶得看也沒關係,他只是提醒你某行程式碼寫這樣不符合規範,程式碼還是可以執行滴別緊張。

https://ithelp.ithome.com.tw/upload/images/20171222/20107247ODuObnUceE.png
https://ithelp.ithome.com.tw/upload/images/20171222/20107247cgMDBG0QTv.png

最後附上程式碼你可以 clone 下來再 npn installyarn install 就可以執行囉!看過喜歡的話按顆星星讓我知道你~哈 Source Code

裡面分別有兩隻 js 檔 index.js 是錯誤並且跳出警示的寫法,correct.js 是依照規範修改後正確的寫法你可以相對照看看。

文章同時發表於:https://andy6804tw.github.io/2017/12/22/ESLint-tutorial/

今天有特別注意有沒有不小心又放localhost/images/emoticon/emoticon01.gif XD


上一篇
[Day-11] JavaScript基礎篇(4)
下一篇
[Day-13] Webpack 與 babel 轉譯
系列文
從無到有,打造一個漂亮乾淨俐落的 RESTful API43
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
O口O
iT邦新手 4 級 ‧ 2022-03-07 20:06:35

請問一下喔.elintrc要放在哪個位置

10程式中 iT邦研究生 4 級 ‧ 2022-03-07 20:26:38 檢舉

O口O
專案資料夾最外層,簡單來說跟 package.json 放同一層資料夾。

O口O iT邦新手 4 級 ‧ 2022-03-07 20:45:40 檢舉

謝謝你喔~

我要留言

立即登入留言