文章目录
- 1. 确认 `vue-cli-service lint` 已集成
- 2. 确认 `lintOnSave` 是否启用
- 示例:`vue.config.js`
- 3. 确认 ESLint 配置
- 4. 确认 Git 钩子配置
- 5. 如何实现保存时自动修复
- (1)启用 `lintOnSave`
- (2)配置编辑器的 ESLint 插件
- (3)测试自动修复
- 6. 总结
从你提供的
package.json
文件来看,项目已经集成了
vue-cli-service lint --fix
,并且配置了相关的工具和脚本。以下是详细分析:
1. 确认 vue-cli-service lint
已集成
在 scripts
部分,有以下脚本:
"scripts": {
"lint": "vue-cli-service lint"
}
- 这表示项目中已经集成了
vue-cli-service lint
。 - 你可以通过运行以下命令手动执行 lint:
或者使用yarn lint
--fix
参数自动修复问题:yarn lint --fix
2. 确认 lintOnSave
是否启用
lintOnSave
是 Vue CLI 的一个配置项,用于在保存文件时自动运行 lint。你需要检查项目根目录下是否有 vue.config.js
文件,并查看是否启用了 lintOnSave
。
示例:vue.config.js
module.exports = {
lintOnSave: true // 保存时自动运行 lint
};
- 如果
lintOnSave
为true
,保存文件时会自动运行vue-cli-service lint
。 - 如果没有
vue.config.js
文件,则默认行为取决于 Vue CLI 的版本(Vue CLI 4+ 默认启用lintOnSave
)。
3. 确认 ESLint 配置
在 devDependencies
中,可以看到以下 ESLint 相关的依赖:
"devDependencies": {
"@vue/cli-plugin-eslint": "^4.2.2",
"@vue/eslint-config-standard": "^4.0.0",
"@vue/eslint-config-typescript": "^4.0.0",
"eslint": "^6.8.0",
"eslint-plugin-vue": "^6.1.2"
}
- 这些依赖表明项目已经配置了 ESLint,并且支持 Vue 和 TypeScript。
- ESLint 配置文件(如
.eslintrc.js
)会使用这些插件和规则。
4. 确认 Git 钩子配置
在 gitHooks
和 lint-staged
部分,有以下配置:
"gitHooks": {
"pre-commit": "lint-staged"
},
"lint-staged": {
"*.{js,vue}": [
"vue-cli-service lint"
]
}
- 这表示在提交代码时(
pre-commit
钩子),会运行lint-staged
。 lint-staged
会对暂存区中的.js
和.vue
文件运行vue-cli-service lint
。
5. 如何实现保存时自动修复
如果你希望在保存文件时自动运行 vue-cli-service lint --fix
,可以通过以下方式实现:
(1)启用 lintOnSave
确保 vue.config.js
中启用了 lintOnSave
:
module.exports = {
lintOnSave: true
};
(2)配置编辑器的 ESLint 插件
如果你使用的是 Cursor 或 VS Code,可以通过以下步骤配置:
- 安装 ESLint 插件。
- 打开编辑器设置(
Ctrl + ,
或Cmd + ,
)。 - 搜索
eslint.autoFixOnSave
,并将其设置为true
。 - 确保
eslint.enable
已启用。
(3)测试自动修复
- 修改一个文件并保存,检查是否自动修复了 ESLint 可修复的问题。
6. 总结
vue-cli-service lint
已集成:可以通过yarn lint
或yarn lint --fix
手动运行。lintOnSave
:如果vue.config.js
中启用了lintOnSave
,保存文件时会自动运行 lint。- Git 钩子:提交代码时会自动运行
vue-cli-service lint
。 - 编辑器集成:通过 ESLint 插件可以实现保存时自动修复。
如果你希望在保存文件时自动修复代码,确保 lintOnSave
已启用,并配置编辑器的 ESLint 插件即可。