Custom ESLint and Prettier config with sensible defaults
npm i -D eslint prettier@2 eslint-config-kouts eslint-config-standard eslint-plugin-html eslint-plugin-import eslint-plugin-n
eslint-plugin-promise eslint-plugin-vue eslint-plugin-prettier eslint-config-prettier eslint-plugin-sort-imports-es6-autofix
For the Vue 3 TypeScript preset we need additionally:
npm i -D @typescript-eslint/parser @vue/eslint-config-typescript vue-eslint-parser
There are 4 ESLint config presets that you can use:
eslint-config-kouts/javascript
for JavaScript / TypeScript projectseslint-config-kouts/vue2
for Vue.js 2 projectseslint-config-kouts/vue3
for Vue.js 3 projectseslint-config-kouts/vue3-typescript
for Vue.js 3 / TypeScript projects
Add the desired config preset into your .eslintrc.js
file:
module.exports = {
extends: ['eslint-config-kouts/vue2']
}
Add a prettier.config.js
file with contents:
module.exports = require('eslint-config-kouts/prettier.config.js')
You can add ESLint commands to .package-json
{
"lint": "eslint \"**/*.{vue,ts,js}\"",
"lint-fix": "eslint --fix \"**/*.{vue,ts,js}\""
}
and VS Code settings for autofix on save
.vscode/settings.json
{
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
}
}
- Based on eslint-config-standard
- Prettier for code formatting
- Plugins
- eslint-plugin-html for linting inline scripts contained in HTML files
- eslint-plugin-vue for linting Vue.js files
- eslint-config-prettier for disabling all rules that conflict with Prettier
- eslint-plugin-prettier for using prettier as a code formatter for
eslint --fix
- sort-imports-es6-autofix for auto-fixing imports order