前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一文读懂 ESLint配置

一文读懂 ESLint配置

作者头像
Qiuner
发布2024-08-06 10:08:14
2130
发布2024-08-06 10:08:14
举报
文章被收录于专栏:杂烩

你好,我是Qiuner. 为帮助别人少走弯路和记录自己编程学习过程而写博客 这是我的 github https://github.com/Qiuner ⭐️ ​ gitee https://gitee.com/Qiuner 🌹 如果本篇文章帮到了你 不妨点个吧~ 我会很高兴的 😄 (^ ~ ^) 想看更多 那就点个关注吧 我会尽力带来有趣的内容 😎 代码都在github或gitee上,可以去上面自行下载 如果你遇到了问题,自己没法解决,可以去我掘金评论区问。私信看不完,CSDN评论区可能会漏看 掘金账号 https://juejin.cn/user/1942157160101860 掘金账号 本篇介绍了代码校验工具ESlint的配置规则与常用的配置项,无论是新手还是老手都能有所收获

前言

博主看来很多网络上的视频教程,发现对ESLint配置的介绍是比较少的。但ESLint是很有用的,一个项目是否健全多人开发一个项目时,能否实现代码风格一致,ESLint在这个过程中是不可替代的。今天就来详细介绍ESLint配置规则,与推荐一些基础的配置。

什么是ESLint

  • ESLint 是一种静态代码分析工具,用于在编写 JavaScript 和 TypeScript 代码时识别和报告问题。它的主要目标是帮助开发者在早期阶段发现代码中的潜在错误和不良模式,确保代码的一致性和高质量。

使用ESLint

一:命令行安装ESLint
代码语言:javascript
复制
npm init @eslint/config
  • 安装后能在包工具中看到
二:在VSCode安装ESLint插件
三:ESLint通过什么来实现代码风格一致与规范写法?

文件名/类型

作用

格式

.eslintrc

定义 ESLint 的规则、环境、解析器、插件等

JSON、YAML 或 JavaScript

eslint.config.js

以 JavaScript 形式编写 ESLint 配置,允许使用更多编程逻辑

JavaScript

.eslintignore

指定 ESLint 应忽略的文件和目录

类似于 .gitignore,一行一个路径

规则定义文件(plugins)

扩展 ESLint 功能,定义一组规则

N/A

  • 简单来说,在你项目引入了ESLint后,你只需要在项目目录下放这些文件,就可以达到配置ESLint的效果
  • 一般情况下,我们在项目中添加 .eslintrc.eslintignore就能够比较健全的使用ESLint了
四:.eslintignore文件配置与文件配置规则
常用的配置规则

在这里,我给出我项目中一般会使用的.eslintignore配置

代码语言:javascript
复制
docs
dist
public
node_modules

.versionrc
auto-imports.d.ts
components.d.ts

**/dist/**
**/public/**
**/docs/**
**/node_modules/**
**/.versionrc/**
**/types/**/*
具体配置规则

配置规则

说明

示例

每行一个模式

每行指定一个路径模式,匹配的文件或目录将被忽略

node_modules/

注释

使用 # 开头的行被视为注释

# 忽略 node_modules 目录

空行

空行会被忽略,用于提高可读性

(空行)

绝对路径和相对路径

路径相对于 .eslintignore 文件所在的位置

logs/

通配符 *

* 匹配零个或多个字符

*.js(匹配所有 .js 文件)

双星号 **

** 匹配任意数量的子目录

src/**(匹配 src 目录下的所有文件和子目录)

否定模式

以 ! 开头的行表示否定模式,用于取消之前的忽略规则

!index.js(不忽略 index.js 文件)

示例
代码语言:javascript
复制
# 忽略 node_modules 目录
node_modules/

# 忽略构建输出目录
dist/
build/

# 忽略所有压缩文件
*.zip

# 忽略所有日志文件
logs/

# 忽略特定文件
src/legacy-code.js

# 忽略特定文件类型
*.min.js

# 忽略所有图片文件
*.png
*.jpg
*.jpeg
*.gif

# 忽略所有子目录中的 .test.js 文件
**/*.test.js

# 否定模式:不忽略 src/index.js 文件
!src/index.js
五:eslint.config.js文件配置与配置规则
常用的配置规则与解释

在这里,我给出我项目中一般会使用的eslint.config.js配置

代码语言:javascript
复制
import antfu from '@antfu/eslint-config'

export default antfu(
  {
    vue: {
      overrides: {
        'vue/operator-linebreak': 'off',
        'vue/singleline-html-element-content-newline': 'off',
        'vue/multi-word-component-names': 'off',
        'vue/no-v-model-argument': 'off',
        'vue/require-default-prop': 'off',
        'vue/require-prop-types': 'off',
        'vue/html-self-closing': 'off',
        'vue/quote-props': 'off',
        'vue/no-irregular-whitespace': 'off',
        'vue/prop-name-casing': 'off',
        'vue/html-indent': 'off',
        'vue/no-reserved-component-names': 'off',
      },
    },
    typescript: true,
  },
  {
    rules: {
      'antfu/if-newline': 'off',
      'style/jsx-closing-tag-location': 'off',
      'import/order': 'off',
      'prefer-const': 'error',
      'node/prefer-global/process': 'off',
      'unused-imports/no-unused-vars': 'off',
      'style/semi': 'off',
      'style/indent': 'off',
      'style/quote-props': 'off',
      'style/brace-style': 'off',
      'style/arrow-parens': 'off',
      'style/indent-binary-ops': 'off',
      'style/operator-linebreak': 'off',
      'style/member-delimiter-style': 'off',
      'no-var': 'error',
      'no-undef': 'off',
      'no-new': 'off',
      'no-param-reassign': 'error',
      'no-console': 'off',
      'no-irregular-whitespace': 'off',
      'unicorn/number-literal-case': 'off',
      'ts/ban-ts-comment': 'off',
    },
  },
)
vue 部分
  • vue 配置 :应用于 Vue 文件的规则覆盖。
    • vue/operator-linebreak: 关闭操作符换行规则。
    • vue/singleline-html-element-content-newline: 关闭单行 HTML 元素内容的新行要求。
    • vue/multi-word-component-names: 关闭组件名称多词规则。
    • vue/no-v-model-argument: 关闭对 v-model 参数的规则。
    • vue/require-default-prop: 关闭默认 prop 需求规则。
    • vue/require-prop-types: 关闭 prop 类型要求规则。
    • vue/html-self-closing: 关闭 HTML 自闭合规则。
    • vue/quote-props: 关闭属性引号规则。
    • vue/no-irregular-whitespace: 关闭不规则空白检查。
    • vue/prop-name-casing: 关闭 prop 名称大小写规则。
    • vue/html-indent: 关闭 HTML 缩进规则。
    • vue/no-reserved-component-names: 关闭保留组件名称检查。
全局 rules 部分
  • rules 配置 :覆盖和配置 ESLint 的全局规则。
    • antfu/if-newline: 关闭 antfu 插件的 if-newline 规则。
    • style/jsx-closing-tag-location: 关闭 JSX 关闭标签位置规则。
    • import/order: 关闭 import 语句的排序规则。
    • prefer-const: 强制使用 const 来声明不被修改的变量。
    • node/prefer-global/process: 关闭对 process 全局变量的偏好规则。
    • unused-imports/no-unused-vars: 关闭未使用的导入变量规则。
    • style/semi: 关闭语句末尾分号规则。
    • style/indent: 关闭缩进规则。
    • style/quote-props: 关闭属性引号规则。
    • style/brace-style: 关闭大括号风格规则。
    • style/arrow-parens: 关闭箭头函数参数的括号规则。
    • style/indent-binary-ops: 关闭二元运算符的缩进规则。
    • style/operator-linebreak: 关闭操作符换行规则。
    • style/member-delimiter-style: 关闭成员分隔符风格规则。
    • no-var: 禁止使用 var 关键字,建议使用 letconst
    • no-undef: 关闭对未定义变量的检查。
    • no-new: 关闭禁止直接使用 new 关键字的规则。
    • no-param-reassign: 禁止重新分配函数参数。
    • no-console: 关闭禁止使用 console 的规则。
    • no-irregular-whitespace: 关闭不规则空白检查规则。
    • unicorn/number-literal-case: 关闭 unicorn 插件的数字字面量大小写规则。
    • ts/ban-ts-comment: 关闭 TypeScript 对 @ts- 注释的禁止规则。
使用eslint.config.js的办法
第一步:导入antfu
代码语言:javascript
复制
import antfu from '@antfu/eslint-config'
第二步:在导入的的函数中编写你的配置项
代码语言:javascript
复制
export default antfu(
{
    vue: {
    overrides:{
            'vue/operator-linebreak': 'off',
        'vue/singleline-html-element-content-newline': 'off',
    }
}
}
)
  • 如上所示,通过这种这种括号之类的来进行对内容的检查

总结

​ 有了ESLint,其实还是不够的,因为这只负责检查语法,而不负责自动格式化,自动格式化规则设置需要使用到Prettier,至于Prettier怎么使用,等待下一期吧

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-08-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 使用ESLint
    • 一:命令行安装ESLint
      • 二:在VSCode安装ESLint插件
        • 三:ESLint通过什么来实现代码风格一致与规范写法?
          • 四:.eslintignore文件配置与文件配置规则
            • 常用的配置规则
            • 具体配置规则
            • 示例
          • 五:eslint.config.js文件配置与配置规则
            • 常用的配置规则与解释
            • 使用eslint.config.js的办法
        • 总结
        相关产品与服务
        腾讯云代码分析
        腾讯云代码分析(内部代号CodeDog)是集众多代码分析工具的云原生、分布式、高性能的代码综合分析跟踪管理平台,其主要功能是持续跟踪分析代码,观测项目代码质量,支撑团队传承代码文化。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档