詳解ESLint在Vue中的使用小結(jié)
ESLint是一個QA工具,用來避免低級錯誤和統(tǒng)一代碼的風(fēng)格
ESLint的用途
1.審查代碼是否符合編碼規(guī)范和統(tǒng)一的代碼風(fēng)格;
2.審查代碼是否存在語法錯誤;
中文網(wǎng)地址 http://eslint.cn/
使用VSCode編譯器在Vue項(xiàng)目中的使用
在初始化項(xiàng)目時選擇是否使用
ESLint管理代碼(選擇Y則默認(rèn)開啟)
Use ESLint to lint your code? (Y/n)

默認(rèn)使用的是此標(biāo)準(zhǔn)https://github.com/standard/standard/blob/master/docs/RULES-zhcn.md
以下是對.editorconfig、.eslintignore、.eslintrc.js 文件進(jìn)行詳細(xì)解釋
.editorconfig文件(主要用于配置IDE)
規(guī)范縮進(jìn)風(fēng)格,縮進(jìn)大小,tab長度以及字符集等,解決不同IDE的編碼范設(shè)置。EditorConfig 插件會去查找當(dāng)前編輯文件的所在文件夾或其上級文件夾中是否有 .editorconfig 文件。如果有,則編輯器的行為會與 .editorconfig 文件中定義的一致,并且其優(yōu)先級高于編輯器自身的設(shè)置。
root = true # 對所有文件有效 //[*js]只對js文件有效 [*] #設(shè)置編碼格式 charset = utf-8 #縮進(jìn)類型 可選space和tab indent_style = space #縮進(jìn)數(shù)量可選整數(shù)值2 or 4,或者tab indent_size = 2 #換行符的格式 end_of_line = lf # 是否在文件的最后插入一個空行 可選true和false insert_final_newline = true # 是否刪除行尾的空格 可選擇true和false trim_trailing_whitespace = true
.eslintignore文件(放置需要ESLint忽略的文件,只對.js文件有效)
/build/ /config/ /dist/ /src/utils/ /src/router/*.js
.eslintrc.js 文件(用來配置ESLint的檢查規(guī)則)
module.exports = {
//此項(xiàng)是用來告訴eslint找當(dāng)前配置文件不能往父級查找
root: true,
//此項(xiàng)是用來指定eslint解析器的,解析器必須符合規(guī)則,babel-eslint解析器是對babel解析器的包裝使其與ESLint解析
parser: 'babel-eslint',
//此項(xiàng)是用來指定javaScript語言類型和風(fēng)格,sourceType用來指定js導(dǎo)入的方式,默認(rèn)是script,此處設(shè)置為module,指某塊導(dǎo)入方式
parserOptions: {
sourceType: 'module'
},
//此項(xiàng)指定環(huán)境的全局變量,下面的配置指定為瀏覽器環(huán)境
env: {
browser: true,
},
// https://github.com/feross/standard/blob/master/RULES.md#javascript-standard-style
// 此項(xiàng)是用來配置標(biāo)準(zhǔn)的js風(fēng)格,就是說寫代碼的時候要規(guī)范的寫,如果你使用vs-code我覺得應(yīng)該可以避免出錯
extends: 'standard',
// required to lint *.vue files
// 此項(xiàng)是用來提供插件的,插件名稱省略了eslint-plugin-,下面這個配置是用來規(guī)范html的
plugins: [
'html'
],
// add your custom rules here
// 下面這些rules是用來設(shè)置從插件來的規(guī)范代碼的規(guī)則,使用必須去掉前綴eslint-plugin-
// 主要有如下的設(shè)置規(guī)則,可以設(shè)置字符串也可以設(shè)置數(shù)字,兩者效果一致
// "off" -> 0 關(guān)閉規(guī)則
// "warn" -> 1 開啟警告規(guī)則
//"error" -> 2 開啟錯誤規(guī)則
// 了解了上面這些,下面這些代碼相信也看的明白了
rules: {
// allow async-await
'generator-star-spacing': 'off',
// allow debugger during development
'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
// js語句結(jié)尾必須使用分號
'semi': ['off', 'always'],
// 三等號
'eqeqeq': 0,
// 強(qiáng)制在注釋中 // 或 /* 使用一致的空格
'spaced-comment': 0,
// 關(guān)鍵字后面使用一致的空格
'keyword-spacing': 0,
// 強(qiáng)制在 function的左括號之前使用一致的空格
'space-before-function-paren': 0,
// 引號類型
"quotes": [0, "single"],
// 禁止出現(xiàn)未使用過的變量
// 'no-unused-vars': 0,
// 要求或禁止末尾逗號
'comma-dangle': 0
}
}
- “off” 或 0 - 關(guān)閉規(guī)則
- “warn” 或 1 - 開啟規(guī)則
- “error” 或 2 - 開啟規(guī)則
如何在老項(xiàng)目中加入ESlint
1. 在目錄中添加.editorconfig、.eslintrc.js、.eslintignore這三個文件
2. 在package.json的”devDependencies”中加入ESlint所需要的包
"babel-eslint": "^7.1.1", "eslint": "^3.19.0", "eslint-config-standard": "^10.2.1", "eslint-friendly-formatter": "^3.0.0", "eslint-loader": "^1.7.1", "eslint-plugin-html": "^3.0.0", "eslint-plugin-import": "^2.7.0", "eslint-plugin-node": "^5.2.0", "eslint-plugin-promise": "^3.4.0", "eslint-plugin-standard": "^3.0.1",
3. 在bulid/webpack.base.conf.js文件中加入ESlint規(guī)則并生效
// 在module的rules中加入
module: {
rules: [
{
test: /\.(js|vue)$/,
loader: 'eslint-loader',
enforce: 'pre',
include: [resolve('src'), resolve('test')],
options: {
formatter: require('eslint-friendly-formatter'),
// 不符合Eslint規(guī)則時只警告(默認(rèn)運(yùn)行出錯)
// emitWarning: !config.dev.showEslintErrorsInOverlay
}
},
]
}
4. 重新bulid代碼運(yùn)行,完美生效!!!!!!
推薦三個VSCode插件
- ESLint (只支持高亮顯示js文件)
- EditorConfig
- Typings(代碼錯誤提示)
常見的報錯
文件末尾存在空行(eol-last)

缺少分號(‘semi': [‘error','always'])

關(guān)鍵字后面缺少空格

字符串沒有使用單引號('quotes': [1, 'single'])

縮進(jìn)錯誤

沒有使用全等(eqeqeq)

導(dǎo)入組件卻沒有使用

new了一個對象卻沒有賦值給某個常量(可以在該實(shí)例前添加此代碼/eslint-disable no-new/忽略ESLint的檢查)

超過一行空白行(no-multiple-empty-lines)

注釋符 // 后面縮進(jìn)錯誤(lines-around-comment)
VScode
用戶配置
{
"workbench.startupEditor": "newUntitledFile",
// 以下是按照ESLint格式化代碼
"vetur.format.defaultFormatter.js": "vscode-typescript",
"javascript.format.insertSpaceBeforeFunctionParenthesis": true,
"editor.quickSuggestions": {
"strings": true
},
"editor.tabSize": 2,
"eslint.validate": [
"javascript",
"javascriptreact",
"html",
"vue",
{
"language": "html",
"autoFix": true
}
],
// "files.autoSave": "onFocusChange",
// "vetur.validation.template": false,
// // 防止格式化代碼后單引號變雙引號
// "prettier.singleQuote": true,
"files.autoSave": "afterDelay",
"files.autoSaveDelay": 1500,
// "git.confirmSync": false
// 配置是否從更新通道接收自動更新。更改后需要重啟。
"update.channel": "none"
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue.js-div滾動條隱藏但有滾動效果的實(shí)現(xiàn)方法
下面小編就為大家分享一篇vue.js-div滾動條隱藏但有滾動效果的實(shí)現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
vue+elementUI動態(tài)生成面包屑導(dǎo)航教程
今天小編就為大家分享一篇vue+elementUI動態(tài)生成面包屑導(dǎo)航教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
手把手帶你使用vue+node作后端連接數(shù)據(jù)庫
為了快速學(xué)習(xí)nodejs制作后端并和數(shù)據(jù)庫進(jìn)行交互的方法,所以趕緊寫一篇這樣的文章出來,下面這篇文章主要給大家介紹了關(guān)于手把手帶你使用vue+node作后端連接數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下2023-03-03
詳解使用VueJS開發(fā)項(xiàng)目中的兼容問題
這篇文章主要介紹了詳解使用VueJS開發(fā)項(xiàng)目中的兼容問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
vue使用SVG實(shí)現(xiàn)圓形進(jìn)度條音樂播放
這篇文章主要為大家詳細(xì)介紹了vue使用SVG實(shí)現(xiàn)圓形進(jìn)度條音樂播放,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04
vue實(shí)現(xiàn)前端拖拽div位置交換的方法詳解
這篇文章主要介紹了如何使用Vue技術(shù)實(shí)現(xiàn)一個簡單的備忘錄應(yīng)用,包括添加條目和拖拽條目兩個功能,文章還詳細(xì)解釋了如何使用Vue的draggable屬性和JavaScript獲取同級元素節(jié)點(diǎn)的方法,需要的朋友可以參考下2025-01-01

