【React】vite + react 项目,进行配置 eslint

安装与配置 eslint

      • 1 安装 eslint @babel/eslint-parser
      • 2 初始化配置 eslint
      • 3 安装 vite-plugin-eslint
      • 4 配置 vite.config.js 文件
      • 5 修改 eslint 默认配置

1 安装 eslint @babel/eslint-parser

npm i -D eslint @babel/eslint-parser

2 初始化配置 eslint

npx eslint --init

相关的配置设置根据实际情况选择即可
在这里插入图片描述
配置完成会自动安装相关依赖并生成 .eslintrc.cjs 文件

module.exports = {
  'env': {
    'browser': true,
    'es2021': true
  },
  'extends': [
    'eslint:recommended',
    'plugin:react/recommended'
  ],
  'overrides': [
    {
      'env': {
        'node': true
      },
      'files': [
        '.eslintrc.{js,cjs}'
      ],
      'parserOptions': {
        'sourceType': 'script'
      }
    }
  ],
  'parserOptions': {
    'ecmaVersion': 'latest',
    'sourceType': 'module'
  },
  'plugins': [
    'react'
  ],
  'rules': {
  },
};

3 安装 vite-plugin-eslint

npm i -D vite-plugin-eslint

4 配置 vite.config.js 文件

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import eslintPlugin from 'vite-plugin-eslint'

export default defineConfig({
  plugins: [
    react(),
    // 添加 eslint 插件配置
    eslintPlugin({
      include: ['src/**/*.js', 'src/**/*.jsx', 'src/*.js', 'src/*.jsx']
    })
  ],
  resolve: {
    alias: {
    },
  },
})

5 修改 eslint 默认配置

可根据实际情况进行配置。

module.exports = {
  'env': {
    'browser': true,
    'es2021': true
  },
  'extends': [
    'eslint:recommended',
    'plugin:react/recommended'
  ],
  'overrides': [
    {
      'env': {
        'node': true
      },
      'files': [
        '.eslintrc.{js,cjs}'
      ],
      'parserOptions': {
        'sourceType': 'script'
      }
    }
  ],
  'parserOptions': {
    'ecmaVersion': 'latest',
    'sourceType': 'module'
  },
  'plugins': [
    'react'
  ],
  'rules': {
    'indent': [
      2,
      2,
      {
        'SwitchCase': 1,
        'ignoredNodes': ['TemplateLiteral']
      }
    ], //缩进
    'no-unused-vars': [0], //未使用变量
    'quotes': [2, 'single'], //单引号
    'jsx-quotes': ['error', 'prefer-single'],
    'no-console': [0, { 'allow': ['warn', 'error'] }], //console
    'linebreak-style': [0, 'unix'], //强制执行统一的行结尾
    'semi': [2, 'always'], //分号结尾
    'curly': 2,
    'no-eval': 1, //禁止使用eval
    'no-caller': 2,
    'no-else-return': 2, //如果if语句里面有return,后面不能跟else语句
    'no-extend-native': 2, //禁止扩展native对象
    'no-extra-bind': 2, //禁止不必要的函数绑定
    'no-floating-decimal': 2, //禁止省略浮点数中的0
    'no-implied-eval': 2, //禁止使用隐式eval
    'no-labels': 2, //禁止标签声明
    'no-with': 2, //禁用with
    'no-loop-func': 0, //禁止在循环中使用函数(如果没有引用外部变量不形成闭包就可以)
    'no-native-reassign': 2, //不能重写native对象
    'no-redeclare': [2], //禁止重复声明变量
    'no-unused-expressions': 0, //禁止无用的表达式
    'no-unneeded-ternary': 2, //禁止不必要的嵌套
    'no-use-before-define': 0, //未定义前不能使用
    'no-unreachable': 2, //不能有无法执行的代码
    'no-trailing-spaces': 1, //一行结束后面不要有空格
    'no-dupe-keys': 2, //在创建对象字面量时不允许键重复 {a:1,a:1}
    'no-dupe-args': 2, //函数参数不能重复
    'no-duplicate-case': 2, //switch中的case标签不能重复
    'array-bracket-spacing': [2, 'never'], //是否允许非空数组里面有多余的空格
    'arrow-body-style': [1],
    'no-undef-init': 0,
    'no-undefined': 0,
    'key-spacing': [
      //对象字面量中冒号的前后空格
      2,
      {
        'beforeColon': false,
        'afterColon': true
      }
    ],
    'no-lonely-if': 2, //禁止else语句内只有if语句
    'no-inner-declarations': [2, 'functions'], //禁止在块语句中使用声明(变量或函数)
    'no-spaced-func': 2, //函数调用时 函数名与()之间不能有空格
    'no-case-declarations': [0],
    'no-multiple-empty-lines': [1, { 'max': 2 }], //空行最多不能超过2行
    'space-in-parens': [2, 'never'], //小括号里面要不要有空格
    'no-multi-spaces': [2], //不能用多余的空格
    'no-irregular-whitespace': 2,//不能有不规则的空格
    'react/prop-types': [0],
    'react/display-name': [0],
    'react/no-string-refs': [0],
    'react/jsx-no-comment-textnodes': [0],
    'react/no-unescaped-entities': [0]
  },
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/504177.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

应急物资管理系统|实现应急物资的全生命周期管理和监控

应急物资管理系统是一种现代化、智能化、可视化的物资管理平台,主要用于实现对应急物资的全生命周期管理和监控,并提供可靠的应急响应支持。 应急物资管理系统功能 准入控制:东识应急物资管理系统可以实现准入控制,确保只有经过授…

C语言----strcmp()函数:比较两个字符串

C语言中strcmp()用于对两个字符串进行比较(区分大小)。 头文件:string.h 语法原型 int strcmp(const char*str1,const char*str2) 参数str1和str2是参与比较的两个字符串。 strcmp()是根据ASCLL编码依次比较str1和str…

MP设置动态表名

Mybatis设置动态表名 Mybatis设置动态表名1.动态表名插件2.传递表名3.注意事项 Mybatis设置动态表名 1.动态表名插件 MybatisPlus中提供了一个动态表名的插件:https://baomidou.com/pages/2a45ff/#dynamictablenameinnerinterceptor 插件的部分源码如下&#xff…

大模型面试准备(十):大模型数据处理方法及优秀的开源数据介绍

节前,我们组织了一场算法岗技术&面试讨论会,邀请了一些互联网大厂朋友、参加社招和校招面试的同学,针对大模型技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何备战、面试常考点分享等热门话题进行了深入的讨论。 合集在这…

【Consul】Linux安装Consul保姆级教程

【Consul】Linux安装Consul保姆级教程 大家好 我是寸铁👊 总结了一篇【Consul】Linux安装Consul保姆级教程✨ 喜欢的小伙伴可以点点关注 💝 前言 今天要把编写的go程序放到linux上进行测试Consul服务注册与发现,那怎么样才能实现这一过程&am…

内网渗透之域环境探索和简单提权

参考文章:http://t.csdnimg.cn/AZ2OR 一个简单的域环境可以这样子搭建: 其中边界服务器有两张网卡,一个是对外的公网网卡,另一张是对内的局域网网卡。一般渗透过程中,拿下这个作为跳板机,进而继续渗透。 …

P23—P25:标识符和关键字

标识符 什么是标识符? 在java源程序中,程序员有权自己命名的单词都是标识符在EditPlus编译器中,表示符以黑色高亮字体显示 标识符可以标识什么元素? 类名方法名变量名接口名常量名 … 标识符的命名规则: 只能由**数…

C++学习随笔(8)——模板初阶

本章我们来学习一下C的模版部分! 目录 1. 泛型编程 2. 函数模板 2.1 函数模板概念 2.1 函数模板格式 2.3 函数模板的原理 2.4 函数模板的实例化 2.5 模板参数的匹配原则 3. 类模板 3.1 类模板的定义格式 3.2 类模板的实例化 1. 泛型编程 如何实现一个通…

Android vehicle车辆属性新增demo

目录 前言一、Vehicle模块1.1 简介1.2 Vehicle框架1.3 主要功能和特点1.4 重要服务CarService1.4.1 简介1.4.2 组成1.4.3 启动时序1.4.4 作用 二、车辆属性新增demo2.1 CarPropertyService2.1.1 简介2.1.2 架构2.1.3 车辆属性 API2.1.4 CarPropertyService 初始化流程 2.2 App …

鸿蒙ARKTS--简易的购物网站

目录 一、media 二、string.json文件 三、pages 3.1 登录页面:gouwuPage.ets 3.2 PageResource.ets 3.3 商品页面:shangpinPage.ets 3.4 我的页面:wodePage.ets 3.5 注册页面:zhucePage.ets 3. 购物网站主页面&#xff…

在GitHub上上传项目(Idea)

repository创建好后,GitHub会提示相应的命令 在Idea的终端执行这些命令,就OK了 在GitHub上查看,已经上传成功

设备树语法

设备树语法 1 Devicetree格式1.1 DTS文件格式1.2 node格式1.3 properties格式 2 dts文件包好desi文件3 常用的 属性 properties3.1 #address-cells、#size-cells3.2 compatible3.3 model3.4 status3.5 reg(设备不同reg属性的含义就不同)3.6 name、device…

企业知识库搭建不再是难题,靠这几个软件就可以了

在当今知识为王的时代,具备一套强大且实用的企业知识库(Knowledge Base)已成为提升工作效率、促进团队合作不可或缺的工具。那么,问题来了,我们该如何搭建一套属于自己的知识库呢?今天,我就给大…

软件工程 - 04 需求分析

文章目录 需求分析需求分析方法系统建模用例图类图对象图活动图时序图协作图构件图部署图 软件开发各个阶段的图 需求分析 软件开发中非常重要的一环;好的需求分析方法,可以帮助更好地理解用户需求,准确定义系统的功能和性能要求&#xff0c…

深入理解数据结构(3):栈和队列详解

文章主题:顺序表和链表详解🌱所属专栏:深入理解数据结构📘作者简介:更新有关深入理解数据结构知识的博主一枚,记录分享自己对数据结构的深入解读。😄个人主页:[₽]的个人主页&#x…

系统优化都没做过?看这篇就够了

目录 一、系统优化指标 二、系统优化简介 三、系统优化 3.1 CPU 高 3.2 内存占用高 业务引起的内存升高 程序自身引起的内存问题 3.3 磁盘I/O 3.4 网络 3.5 数据库优化 3.6 响应时间高 3.7 吞吐量 3.8 代码层面优化 3.9 业务优化 四、JVM优化 4.1 堆内存设置 4.2 选择何时的…

半导体工艺技术

完整内容点击:【半导体工艺技术】

win10蓝牙开关不见了怎么办,win10设置里面蓝牙开关不见了

最近,有用户在使用win10系统的时候,发现设置蓝牙和其他设备中蓝牙开关不见了。正常情况下,“蓝牙和其他设备”下面是有蓝牙开启开关的,没有的话是怎么回事呢?出现这样的情况,可能是应为系统没有将测到蓝牙设备或者蓝牙…

高德地图key注册教程_地图数据采集软件

1.先注册成为开发者账号。 2.再申请高德地图Key。 3.把申请得到的高德地图Key填入软件中。 1.请先打开以下连接 高德地图key注册地址 易地图数据采集大师手机App版介绍 易地图数据采集大师电脑PC版介绍 2.注册新用(如果已有开发者账号,本步可省略&am…

知识蒸馏详解及pytorch官网demo案例

知识蒸馏Knowledge Distillation(KD) 1、简介 一种模型压缩方法 知识蒸馏的一般框架(如下图) 三部分:知识、蒸馏算法、师生架构。 知识 将知识分为三种形式:基于响应的(response-based)、基于特征的&…