VS Code使用之Vue工程配置eslint

首先確保VS Code 安裝了 VeturEslint 插件。
然後使用了vue-cli提供的簡單webpack模板,這樣創建的工程默認沒有添加ESLint。

vue init webpack-simple test-vscode

配置過程

  1. 全局安裝最新的eslint
npm i -g eslint@latest

運行

eslint --init

eslint-init

會安裝以下依賴

eslint-config-standard@latest
eslint-plugin-import@>=2.2.0
eslint-plugin-node@>=5.2.1
eslint-plugin-promise@>=3.5.0
eslint-plugin-standard@>=3.0.0

同時在項目目錄下生成.eslintrc.js文件。裏面只有最基本的內容:

module.exports = {
    "extends": "standard"
};

表明我們使用的規則是standard規範所定義的規則。
2. 然後本地安裝最新的eslint

npm i -D eslint@latest
  1. package.jsonscripts中添加一行:
 "lint": "eslint --ext .js,.vue src"

運行:

npm run lint

VS Code會提示我們找不到eslint-config-standard
報錯提示

安裝它:

npm i -D eslint-config-standard

然後運行

npm run lint

這時就會有報錯的提示了。
lint_err

code_err
4. 但是在.vue文件中出錯的地方並沒有相應的提示。這時Vetur排上用場了。 在VS Code的設置裏面添加如下規則:

{
"eslint.validate": [
        "javascript",
        "javascriptreact",
        {
             "language": "vue",
            "autoFix": true
        }
    ]
}

這樣就添加了對.vue文件的支持。
5. 但是這樣會對.vue文件中的標籤報解析錯誤
parser_error
這時需要安裝eslint-plugin-vue@next插件。

 npm install -D eslint-plugin-vue@next

同時在.eslintrc.js中添加使用vue插件的擴展。

// .eslintrc.js
module.exports = {
    "extends": [
           "standard",
           "plugin:vue/base"
      ]
}

這樣,就可以對.vue文件提供實時檢查的功能了。
6. 對於多餘的逗號這種錯誤,可以在保存的時候讓eslint插件自動修復。 更改VS Code中的設置,添加如下規則:

{
  "eslint.autoFixOnSave": true
}

總結

通過使用VS Code的插件 VeturESLint來對Vue工程中的.vue提供代碼檢查的功能。
1. 需要安裝的依賴:
json
"eslint": "^4.14.0",
"eslint-config-standard": "^11.0.0-beta.0",
"eslint-plugin-import": "^2.8.0",
"eslint-plugin-node": "^5.2.1",
"eslint-plugin-promise": "^3.6.0",
"eslint-plugin-standard": "^3.0.1",
"eslint-plugin-vue": "^4.0.0-beta.4",

注意: 這裏 ESLinteslint-plugin-vue需要是最新的。
2. .eslintrc的配置
js
module.exports = {
"extends": [
"standard",
"plugin:vue/base"
]
};

3. VS Code 的配置
json
{
"eslint.validate": [
"javascript",
"javascriptreact",
{
"language": "vue",
"autoFix": true
}
],
"eslint.autoFixOnSave": true
}

參考資料:
Vetur文檔
ESLint文檔
eslint-plugin-vue

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章