首先確保VS Code 安裝了 Vetur 和 Eslint 插件帕涌。
然后使用了vue-cli提供的簡單webpack模板,這樣創(chuàng)建的工程默認(rèn)沒有添加ESLint亲澡。
vue init webpack-simple test-vscode
配置過程
- 全局安裝最新的eslint
npm i -g eslint@latest
運行
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
文件纫版。里面只有最基本的內(nèi)容:
module.exports = {
"extends": "standard"
};
表明我們使用的規(guī)則是standard
規(guī)范所定義的規(guī)則。
- 然后本地安裝最新的eslint
npm i -D eslint@latest
- 在
package.json
的scripts
中添加一行:
"lint": "eslint --ext .js,.vue src"
運行:
npm run lint
VS Code會提示我們找不到eslint-config-standard
:
安裝它:
npm i -D eslint-config-standard
然后運行
npm run lint
這時就會有報錯的提示了癞己。
- 但是在
.vue
文件中出錯的地方并沒有相應(yīng)的提示痹雅。這時Vetur排上用場了糊识。 在VS Code的設(shè)置里面添加如下規(guī)則:
{
"eslint.validate": [
"javascript",
"javascriptreact",
{
"language": "vue",
"autoFix": true
}
]
}
這樣就添加了對.vue
文件的支持。
- 但是這樣會對
.vue
文件中的標(biāo)簽報解析錯誤
這時需要安裝eslint-plugin-vue@next
插件愉耙。
npm install -D eslint-plugin-vue@next
同時在.eslintrc.js
中添加使用vue插件的擴(kuò)展拌滋。
// .eslintrc.js
module.exports = {
"extends": [
"standard",
"plugin:vue/base"
]
}
這樣,就可以對.vue
文件提供實時檢查的功能了败砂。
- 對于多余的逗號這種錯誤,可以在保存的時候讓eslint插件自動修復(fù)吠卷。 更改VS Code中的設(shè)置沦零,添加如下規(guī)則:
{
"eslint.autoFixOnSave": true
}
總結(jié)
通過使用VS Code的插件 Vetur 、ESLint來對Vue工程中的.vue
提供代碼檢查的功能路操。
- 需要安裝的依賴:
注意:"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",
這里 ESLint
和eslint-plugin-vue
需要是最新的屯仗。 -
.eslintrc
的配置
module.exports = {
"extends": [
"standard",
"plugin:vue/base"
]
};
```
3. VS Code 的配置
```json
{
"eslint.validate": [
"javascript",
"javascriptreact",
{
"language": "vue",
"autoFix": true
}
],
"eslint.autoFixOnSave": true
}
```
參考資料:
[Vetur文檔](https://vuejs.github.io/vetur/linting-error.html)
[ESLint文檔](https://eslint.org/docs/user-guide/getting-started)
[eslint-plugin-vue](https://github.com/vuejs/eslint-plugin-vue)