非常规Vue项目配置ESlint和Prettier

简介: 这里的非常规指的是,不是使用 `Vue Cli` 这种工具包去创建的项目,或者创建了但是没有加上 `ESlint` 的配置,比如下面这个

前言

这里的非常规指的是,不是使用 Vue Cli 这种工具包去创建的项目,或者创建了但是没有加上 ESlint 的配置,比如下面这个

"dependencies": {
  "ant-design-vue": "^3.2.13",
  "axios": "^1.1.2",
  "core-js": "^3.8.3",
  "vue": "^3.2.13",
  "vue-router": "^4.0.3",
  "vuex": "^4.0.0"
},
"devDependencies": {
  "@vue/cli-plugin-babel": "~5.0.0",
  "@vue/cli-plugin-router": "~5.0.0",
  "@vue/cli-plugin-vuex": "~5.0.0",
  "@vue/cli-service": "~5.0.0",
},

本篇文章不涉及 typescript 的配置

ESlint

ESlint 的配置需要安装以下包

npm install --save-dev eslint eslint-plugin-vue

ESlint 不必多说,eslint-plugin-vue 这个包请看文档,作用如下

This plugin allows us to check the <template> and <script> of .vue files with ESLint, as well as Vue code in .js files.

再创建 ESLint 的配置文件 .eslintrc.js

module.exports = {
  extends: ["plugin:vue/vue3-recommended"],
};

关于 eslint-config-vue 的配置选项可以参考文档

完成上面的操作后可以看到项目的 ESlint 已经生效了

IMG

Prettier

对于格式化,有些公司会采用 ESLint 去格式化,或者自动保存的时候去 ESlint 一下,但对于某些场景 ESlint 格式化不太好用,比如标签长度超过编辑器默认最大长度(120 个字符),ESlint 做不到自动换行和属性自动排列,所以格式化我选择 Prettier,而且我目前最常用的 IDE - webstorm 的默认格式化也是采用的 Prettier

Prettier 的配置需要安装以下包

npm install --save-dev prettier eslint-config-prettier

eslint-config-prettier 这个库主要是用来解决和 eslint 的冲突,主要表现在你使用 IDE 的格式化快捷键之后会报一堆 ESLint 格式错误,参考文档

安装之后需要在 eslint 配置文件 .eslintrc.js 中加入下列语句

module.exports = {
  // ...
  extends: ["plugin:vue/vue3-recommended", "prettier"],
  // ...
};

使用 Prettier 格式化需要分 IDE 来讲

WebStorm

WebStormwindows 格式化快捷键是 Ctrl + Alt + L 默认使用的格式化包就是 Prettier,如果是只使用 ESLint 管理项目规范,很容易就有代码不一冲突,因为 ESLint 并不会对代码格式化做强制要求,但项目组每个人的写法可能很不一样,这时候 Commit 时就会很多冲突需要提交,类似下面这段代码,ESLint 是不会做任何修改的

  methods: {
    fun() {
      const type = ["string", "number", "undefined", "symbol", "boolean", "bigint", "null"];
    }
  }

但是 Prettier 会强制换行

methods: {
    fun() {
      const type = [
        "string",
        "number",
        "undefined",
        "symbol",
        "boolean",
        "bigint",
        "null",
      ];
    },
  },

诸如此类的细节还有很多,处理冲突时总是很麻烦,所以需要加入 Prettier 管理规范

下面是 WebStorm 配置 Prettier 的操作

安装插件

WebStorm 的插件市场下载 Prettier 插件

IMG

配置 Prettier 库的位置

文件 -> 设置 -> 语言和框架 -> Prettier 下拉选择你项目的 Prettier(注意是项目而不是全局的 Prettier !!!)

IMG

检查是否生效

  1. 使用 Prettier 插件快捷键格式化项目某一文件

    1. 文件 -> 设置 -> 键盘映射 -> 搜索 prettier,即可看到对应的快捷键映射
  2. 基于命令行终端 Prettier 格式化
  3. 检查两种格式化是否一致

如何使用终端的 Prettier?

npx prettier --write your-file-path

注意不要用到全局的 Prettier 而是项目的 Prettier !!!

NOTE: 可以通过查看 Prettier 版本来判断

# 全局安装的 Prettier 版本查看
prettier -v
# 项目的 Prettier 版本查看
npx prettier -v

注意

WebStormPrettier 格式化快捷键和 IDE 默认的快捷键不同

  1. 默认: Ctrl + Alt + L
  2. Prettier: Ctrl + Alt + Shift + P

有可能快捷键无效,可能原因有两种

  1. 和运行中的某个软件有热键冲突
  2. Prettier 没找到项目的包(也就是上面说的配置 Prettier 库的位置的操作)

下面是 VS Code 配置 Prettier 的操作

VS Code

安装插件

IMG

配置默认格式化

IMG

IMG

检查是否生效

  1. 使用 Prettier 插件快捷键格式化项目某一文件
  2. 基于命令行终端 Prettier 格式化
  3. 检查两种格式化是否一致

VS Code 配置 Prettier 的好处是会自动检索项目的 Prettier 包的位置,而不是像 WebStorm 一样要自己去添加

相关文章
|
6月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
563 2
|
5月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
467 137
|
9月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
1013 0
|
9月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
8月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
602 1
|
9月前
|
JavaScript 前端开发 开发者
Vue 自定义进度条组件封装及使用方法详解
这是一篇关于自定义进度条组件的使用指南和开发文档。文章详细介绍了如何在Vue项目中引入、注册并使用该组件,包括基础与高级示例。组件支持分段配置(如颜色、文本)、动画效果及超出进度提示等功能。同时提供了完整的代码实现,支持全局注册,并提出了优化建议,如主题支持、响应式设计等,帮助开发者更灵活地集成和定制进度条组件。资源链接已提供,适合前端开发者参考学习。
616 17
|
8月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
416 0
|
9月前
|
JavaScript 前端开发 UED
Vue 表情包输入组件实现代码及详细开发流程解析
这是一篇关于 Vue 表情包输入组件的使用方法与封装指南的文章。通过安装依赖、全局注册和局部使用,可以快速集成表情包功能到 Vue 项目中。文章还详细介绍了组件的封装实现、高级配置(如自定义表情列表、主题定制、动画效果和懒加载)以及完整集成示例。开发者可根据需求扩展功能,例如 GIF 搜索或自定义表情上传,提升用户体验。资源链接提供进一步学习材料。
548 1
|
9月前
|
存储 JavaScript 前端开发
如何高效实现 vue 文件批量下载及相关操作技巧
在Vue项目中,实现文件批量下载是常见需求。例如文档管理系统或图片库应用中,用户可能需要一次性下载多个文件。本文介绍了三种技术方案:1) 使用`file-saver`和`jszip`插件在前端打包文件为ZIP并下载;2) 借助后端接口完成文件压缩与传输;3) 使用`StreamSaver`解决大文件下载问题。同时,通过在线教育平台的实例详细说明了前后端的具体实现步骤,帮助开发者根据项目需求选择合适方案。
875 0
|
9月前
|
JavaScript 前端开发 UED
Vue 项目中如何自定义实用的进度条组件
本文介绍了如何使用Vue.js创建一个灵活多样的自定义进度条组件。该组件可接受进度段数据数组作为输入,动态渲染进度段,支持动画效果和内容展示。当进度超出总长时,超出部分将以红色填充。文章详细描述了组件的设计目标、实现步骤(包括props定义、宽度计算、模板渲染、动画处理及超出部分的显示),并提供了使用示例。通过此组件,开发者可根据项目需求灵活展示进度情况,优化用户体验。资源地址:[https://pan.quark.cn/s/35324205c62b](https://pan.quark.cn/s/35324205c62b)。
446 0

热门文章

最新文章