赞
踩
首先安装eslint
npm i eslint -D
生成配置文件:.eslint.cjs 【初始化一个eslint 的文件】
npx eslint --init
安装配置完成之后,src文件夹下面会多一个
.eslintrc.cjs
文件——【就是eslint工作说明书,配置文件】
- module.exports = {
- //运行环境
- "env": {
- "browser": true,
- "es2021": true
- },
- //规则继承
- "extends": [
- "eslint:recommended",
- "plugin:@typescript-eslint/recommended",
- "plugin:vue/vue3-essential"
- ],
- //要为特定类型的文件指定处理器
- "overrides": [
- {
- "env": {
- "node": true
- },
- "files": [
- ".eslintrc.{js,cjs}"
- ],
- "parserOptions": {
- "sourceType": "script"
- }
- }
- ],
- //指定解析器:解析器
- //Esprima 默认解析器
- //Babel-ESLint babel解析器
- //@typescript-eslint/parser ts解析器
-
- //指定解析器选项
-
- "parserOptions": {
- "ecmaVersion": "latest",
- "parser": "@typescript-eslint/parser",
- "sourceType": "module"
- },
- //ESLint支持使用第三方插件。在使用插件之前,您必须使用npm安装它
- //该eslint-plugin-前缀可以从插件名称被省略
- "plugins": [
- "@typescript-eslint",
- "vue"
- ],
- //eslint规则
- "rules": {
- }
- }
'运行
- # 让所有与prettier规则存在冲突的Eslint rules失效,并使用prettier进行代码检查
- "eslint-config-prettier": "^8.6.0",
- "eslint-plugin-import": "^2.27.5",
- "eslint-plugin-node": "^11.1.0",
- # 运行更漂亮的Eslint,使prettier规则优先级更高,Eslint优先级低
- "eslint-plugin-prettier": "^4.2.1",
- # vue.js的Eslint插件(查找vue语法错误,发现错误指令,查找违规风格指南
- "eslint-plugin-vue": "^9.9.0",
- # 该解析器允许使用Eslint校验所有babel code
- "@babel/eslint-parser": "^7.19.1",
npm install -D eslint-plugin-import eslint-plugin-vue eslint-plugin-node eslint-plugin-prettier eslint-config-prettier eslint-plugin-node @babel/eslint-parser
- // @see https://eslint.bootcss.com/docs/rules/
-
- module.exports = {
- env: {
- browser: true,
- es2021: true,
- node: true,
- jest: true,
- },
- /* 指定如何解析语法 */
- parser: 'vue-eslint-parser',
- /** 优先级低于 parse 的语法解析配置 */
- parserOptions: {
- ecmaVersion: 'latest',
- sourceType: 'module',
- parser: '@typescript-eslint/parser',
- jsxPragma: 'React',
- ecmaFeatures: {
- jsx: true,
- },
- },
- /* 继承已有的规则 */
- extends: [
- 'eslint:recommended',
- 'plugin:vue/vue3-essential',
- 'plugin:@typescript-eslint/recommended',
- 'plugin:prettier/recommended',
- ],
- plugins: ['vue', '@typescript-eslint'],
- /*
- * "off" 或 0 ==> 关闭规则
- * "warn" 或 1 ==> 打开的规则作为警告(不影响代码执行)
- * "error" 或 2 ==> 规则作为一个错误(代码不能执行,界面报错)
- */
- rules: {
- // eslint(https://eslint.bootcss.com/docs/rules/)
- 'no-var': 'error', // 要求使用 let 或 const 而不是 var
- 'no-multiple-empty-lines': ['warn', { max: 1 }], // 不允许多个空行
- 'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off',
- 'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
- 'no-unexpected-multiline': 'error', // 禁止空余的多行
- 'no-useless-escape': 'off', // 禁止不必要的转义字符
-
- // typeScript (https://typescript-eslint.io/rules)
- '@typescript-eslint/no-unused-vars': 'error', // 禁止定义未使用的变量
- '@typescript-eslint/prefer-ts-expect-error': 'error', // 禁止使用 @ts-ignore
- '@typescript-eslint/no-explicit-any': 'off', // 禁止使用 any 类型
- '@typescript-eslint/no-non-null-assertion': 'off',
- '@typescript-eslint/no-namespace': 'off', // 禁止使用自定义 TypeScript 模块和命名空间。
- '@typescript-eslint/semi': 'off',
-
- // eslint-plugin-vue (https://eslint.vuejs.org/rules/)
- 'vue/multi-word-component-names': 'off', // 要求组件名称始终为 “-” 链接的单词
- 'vue/script-setup-uses-vars': 'error', // 防止<script setup>使用的变量<template>被标记为未使用
- 'vue/no-mutating-props': 'off', // 不允许组件 prop的改变
- 'vue/attribute-hyphenation': 'off', // 对模板中的自定义组件强制执行属性命名样式
- },
- }
'运行
在src文件夹下生成一个
.eslintignore // 文件
把
- dist
- node_modules
写入
package.json新增两个运行脚本
- "scripts": {
- "lint": "eslint src", //当运行指令的时候让eslint 校验src文件里面的文件语法
- "fix": "eslint src --fix", // 把不符合规则的语法进行修整
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。