首页 > 其他分享 >如何使用ESLint?这是80%最常用的功能

如何使用ESLint?这是80%最常用的功能

时间:2024-07-28 20:28:48浏览次数:19  
标签:常用 vue no 80% js ESLint alert config eslint

你好同学,我是沐爸,欢迎点赞、收藏和关注!个人知乎、公众号"沐爸空间"

ESLint 是一个可配置的 JavaScript linter。它可以帮助开发者查找并修复 JavaScript 代码中的问题。通过这篇文章你可以掌握 ESLint 的基本使用、规则配置、规则禁用、文件忽略、工具集成,了解预定义全局变量和插件。

一、基本使用

安装依赖

npm i eslint -D

初始化配置

npx eslint --init

按照提示可以进行自定义配置,如前端框架vue或/eact、是否使用TypeScript、使用场景browser/node,采用的包管理工具等,完成后生成配置文件 eslint.config.mjs:

import globals from "globals";
import pluginJs from "@eslint/js";
import pluginVue from "eslint-plugin-vue";

export default [
  {files: ["**/*.{js,mjs,cjs,vue}"]},
  {languageOptions: { globals: globals.browser }},
  pluginJs.configs.recommended, // ESLint推荐配置
  ...pluginVue.configs["flat/essential"] // Vue插件配置
];

注意:所有配置均需使用 eslint.config.mjs文件,老的 eslintrc.js 和 .eslintrc.json已不再被支持。

配置脚本 package.json

"scripts": {
  "eslint": "eslint src",
  "eslint:fix": "eslint src --fix",
}

运行脚本

npm run eslint
npm run eslint:fix

运行完脚本会在控制台看到不符合 ESLint 规范的错误提示。

二、预定义全局变量

预定义全局变量的作用是什么?比如说代码中使用了 document 变量,如果没有使用预定义配置,且 document 未定义,那么 document 就属于未定义使用,进而会触发警告。由此可以看出,预定义全局变量的作用是对部分变量进行放行,不再检测。

// eslint.config.js
import globals from "globals";

export default [
    {
        languageOptions: {
            globals: globals.browser
        }
    }
]

以 globals.browser 为例,它预定义了哪些全局变量呢?下面仅列出部分几个常见的,了解全部请查看 globals 安装包。

type GlobalsBrowser = {
	readonly 'addEventListener': false;
	readonly 'alert': false;
  readonly 'blur': false;
  readonly 'clearInterval': false;
	readonly 'clearTimeout': false;
  readonly 'console': false;
  readonly 'document': false;
}

三、插件

ESLint 虽然可以定义很多的 rules,但是它本身只是检查 JavaScript 语法。如果要检查 Vue 中的 template 或者React 中的 jsx 语法,它就不行了,但是插件可以。插件可以增强 ESLint 的检查能力和范围。

以上方基本应用中的 eslint.config.mjs 为例,"eslint-plugin-vue" 就是为了检测 Vue 文件而安装的插件,pluginVue.configs["flat/essential"] 中包含了 Vue 插件的配置和规则:

[
  {
    name: 'vue:base:setup',
    plugins: { vue: [Getter] },
    languageOptions: { sourceType: 'module', globals: [Object] }
  },
  {
    name: 'vue:base:setup-for-vue',
    files: [ '*.vue', '**/*.vue' ],
    plugins: { vue: [Getter] },
    languageOptions: { parser: [Object], sourceType: 'module', globals: [Object] },
    rules: { 'vue/comment-directive': 'error', 'vue/jsx-uses-vars': 'error' },
    processor: 'vue/vue'
  },
  {
    name: 'vue:essential:rules',
    rules: {
      'vue/multi-word-component-names': 'error',
      'vue/no-arrow-functions-in-watch': 'error',
      'vue/no-async-in-computed-properties': 'error',
      'vue/no-child-content': 'error',
      'vue/no-computed-properties-in-data': 'error',
      'vue/no-deprecated-data-object-declaration': 'error',
      'vue/no-deprecated-destroyed-lifecycle': 'error',
      ......
    }
  }
]

需要自己创建插件的话,可以看这里:Create Plugins - ESLint - Pluggable JavaScript Linter

四、配置规则

要更改规则的严重性,请将规则 ID 设置为以下值之一:

  • "off"或者0 - 关闭规则
  • "warn"或者1 - 将规则作为警告打开(不会导致程序退出)
  • "error"或者2 - 将规则作为错误打开(当被触发的时候,程序会退出)

例:

export default [
    {
        rules: {
            semi: "error" // 行尾需要分号
        }
    }
];

配置冲突时如何处理?当多个配置对象指定相同的规则时,规则将进行合并,后定义的配置会覆盖先定义的。

情形一:完全覆盖

export default [
    {
        rules: {
            semi: ["error", "never"]
        }
    },
    {
        rules: {
            semi: ["warn", "always"]
        }
    }
];

合并后的配置为:semi: ["warn", "always"]

情形二:部分覆盖

export default [
    {
        rules: {
            semi: ["error", "never"]
        }
    },
    {
        rules: {
            semi: ["warn"]
        }
    }
];

合并后的配置为:semi: ["warn", "never"]

五、禁用规则

如果某一个文件或某一行代码不要需要校验规则,或者需要临时关闭校验,该怎么处理呢?

1.使用配置文件

export default [
    {
        rules: {
            "semi": "error" // 全局生效,行尾需要分号
        }
    },
    {
        files: ["*.config.js"],
        rules: {
            "semi": "off" // 以.config.js结尾的文件关闭结尾分号校验
        }
    }
];

2.使用配置注释

首先要明确的是,最好使用 ESLint 配置文件,也就是上面的方式一,而不是禁用注释。

开发同学应该谨慎使用ESLint内联规则,尽量作为临时方案使用,使用时应提供一条注释,解释禁用特定规则的原因。

1.禁用文件的一部分代码

* eslint-disable */

alert('foo');

/* eslint-enable */

2.还可以禁用或启用特定规则的警告:

/* eslint-disable no-alert, no-console */

alert('foo');
console.log('bar');

/* eslint-enable no-alert, no-console */

3.禁用整个文件中的规则警告:

/* eslint-disable */

alert('foo');

4.可以禁用或启用整个文件的特定规则:

/* eslint-disable no-alert */

alert('foo');

5.禁用特定行上的所有规则,请使用以下格式之一的行或块注释:

alert('foo'); // eslint-disable-line

// eslint-disable-next-line
alert('foo');

/* eslint-disable-next-line */
alert('foo');

alert('foo'); /* eslint-disable-line */

6.禁用特定行上的特定规则,请执行以下操作:

alert('foo'); // eslint-disable-line no-alert

// eslint-disable-next-line no-alert
alert('foo');

alert('foo'); /* eslint-disable-line no-alert */

/* eslint-disable-next-line no-alert */
alert('foo');

7.要在特定行上禁用多个规则:

alert('foo'); // eslint-disable-line no-alert, quotes, semi

// eslint-disable-next-line no-alert, quotes, semi
alert('foo');

alert('foo'); /* eslint-disable-line no-alert, quotes, semi */

/* eslint-disable-next-line no-alert, quotes, semi */
alert('foo');

/* eslint-disable-next-line
  no-alert,
  quotes,
  semi
*/
alert('foo');

8.关于注释说明

配置注释可以包含说明,以解释为什么需要禁用或重新启用规则。描述必须位于配置之后,并且需要用两个或多个连续字符与配置分隔。例如:

// eslint-disable-next-line no-console -- Here's a description about why this configuration is necessary.
console.log('hello');

/* eslint-disable-next-line no-console --
 * Here's a very long description about why this configuration is necessary
 * along with some additional information
**/
console.log('hello');

六、忽略文件

你可以通过以下方式忽略某些文件和目录:

1.忽略文件

// eslint.config.js
export default [
    {
      ignores: [".config/*", 'vue.config.js'],
    }
];

.config 目录下的所有文件和 vue.config.js 文件都将被忽略。

2.忽略目录

假如目录结构是这样的:

├── .config
│   ├── demo1.js
│   └── demo2.js
├── foo
│   └── .config
│       ├── demo3.js
│       └── demo4.js
└── eslint.config.js

忽略目录的工作方式与忽略文件的工作方式相同,以下代码将忽略整个目录(这意味着文件搜索根本不会遍历到其中):

// eslint.config.js
export default [
    {
        ignores: [".config/"]
    }
];

上面的忽略模式只会忽略与配置文件 eslint.config.js 位于同一目录中的目录,只有demo1.js和demo2.js被忽略。如果要递归忽略所有已命中的目录,则需要使用 如下示例:

// eslint.config.js
export default [
    {
        ignores: ["**/.config/"]
    }
];

修改成上面的忽略模式后,.config和foo/.config目录下的文件都将被忽略。

3.不忽略文件和目录

你还可以取消忽略被先前模式(包括默认模式)忽略的文件和目录。例如,此配置取消忽略:

// eslint.config.js
export default [
    {
        ignores: [
            "!node_modules/",           // unignore `node_modules/` directory
            "node_modules/*",           // ignore its content
            "!node_modules/mylibrary/"  // unignore `node_modules/mylibrary` directory
        ]
    }
];

七、命令行

命令行包含很多内容,像基础配置、指定解析器、指定规则和插件、修复问题、忽略文件、输出和缓存等。这里只讲几个平时最常用的命令。

1.文件检测

# 运行两个文件
npx eslint file1.js file2.js

# 检测src和scripts目录
npx eslint src scripts

你也可以省略文件参数,ESLint 将使用 . 进行检测所有匹配文件,这两行执行相同的操作:

npx eslint .
npx eslint

2.指定文件类型

# 仅检测src下js文件
npx eslint src/**/*.js

老版本的 ESLint 可以通过 --ext 选项指定文件类型,下面这种方式目前已被弃用:

npx eslint --ext .vue,.js src/

3.文件修复

npx eslint --fix file.js

--fix选项是 ESLint 提供自动修复基础错误的功能,它只能修复一些基础的不影响代码逻辑的错误,比如代码末尾加上分号、表达式的空格等。

八、集成

1.编辑器:Visual Studio Code:ESLint 扩展

ESLint插件能够检测 JavaScript 中的语法错误和潜在的逻辑错误。如果代码中存在不符合规范的地方,ESLint 会在 VSCode 编辑器中直接显示错误或警告信息,帮助开发同学及时发现并修复问题。没有安装的话,赶紧安装试试吧。

2.源代码管理:Git 提交钩子

使用 Git 提交钩子可以进行代码检测和修复。上传代码前如何自动化修复 ESLint 错误,可以参考我的上一篇:如何利用ESLint、StyleLint、Prettie保持前端代码的一致性?

标签:常用,vue,no,80%,js,ESLint,alert,config,eslint
From: https://blog.csdn.net/m0_37943716/article/details/140728106

相关文章

  • Linux常用打包压缩命令
    压缩命令应用场景tar大部分使用tar即可。创建,查看,解压,解压到指定目录gzip一般配合其他命令使用zip+unzip一般用于解压zip格式的压缩包1.tar打包压缩命令1.1命令详解【功能说明】在Linux系统里,tar是将多个文件打包在一起,并且可以实现解压打包的文件的命令。是系统管理......
  • Ansible常用命令
    ansible-playbook#ansible-playbookplaybook.yml#基本执行#ansible-playbookplaybook.yml--check#模拟执行Playbook,显示将要发生的变化,但不实际执行#ansible-playbookplaybook.yml-......
  • python刷题常用模板
    #=====================================素数筛Begin=====================================#MAXN=1000prime=[]isprime=[True]*(MAXN+1)defeuler():isprime[1]=Falseforiinrange(2,MAXN+1):ifisprime[i]:prime.append(i)......
  • 【嵌入式DIY实例-ESP8266篇】- LCD ST7789显示BME280传感器数据
    LCDST7789显示BME280传感器数据文章目录LCDST7789显示BME280传感器数据1、硬件准备2、代码实现本文将介绍如何使用ESP8266NodeMCU开发板(ESP12-E模块)和BME280气压、温度和湿度传感器构建一个简单的气象站。NodeMCU微控制器(ESP8266EX)从BME280......
  • 30 列表常用方法——append()、insert()、extend()
    append()、insert()、extend()这3个方法都可以用于向列表对象中添加元素。①append()用于向列表尾部追加一个元素。②insert()用于向列表任意指定位置插入一个元素。③extend()用于将另一个列表中的所有元素追加至当前列表的尾部。这3个方法都属于原地操作,不......
  • matlab 常用数据类型的转换
    目录一、数据类型1、整型2、浮点型3、逻辑型4、元胞数组5、结构体二、数据类型转换三、图像数据类型转换四、参考链接一、数据类型1、整型  int和unit都是整型,只是前一个有符号,后一个没有符号,比如在16位系统中,int范围是-32768-32767,unit范围是0-65535。2、浮点......
  • 每日一知识点 - Java常用关键字
    目录......
  • Linux 最常用命令!
    Linux最常用命令![点击下载文档]Linux是目前应用最广泛的服务器操作系统,基于Unix,开源免费,由于系统的稳定性和安全性,市场占有率很高,几乎成为程序代码运行的最佳系统环境。linux不仅可以长时间的运行我们编写的程序代码,还可以安装在各种计算机硬件设备中,如手机、路由器等,And......
  • fastjson反序列化漏洞原理及<=1.2.24&<=1.2.47&Fastjson v1.2.80简单利用&不出网判断&修
    1、什么是fastjsonfastjson是一个有阿里开发的一个开源Java类库,可以将Java对象转换为JSON格式(序列化),当然它也可以将JSON字符串转换为Java对象(反序列化)。2、漏洞原理FastJson在解析json的过程中,⽀持使⽤autoType来实例化某⼀个具体的类,并调⽤该类的set/get⽅法......
  • Vue入门(二)常用指令
    一、Vue常用指令Vue常用指令-指令:是带有v-前缀的特殊属性,不同指令具有不同含义。例如v-html,v-if,v-for。-使用指令时,通常编写在标签的属性上,值可以使用JS的表达式。-常用指令  二、常用指令介绍2.1文本插值v-html:-v-html:把文本解......