Vue3 -- 项目配置之eslint【企业级项目配置保姆级教程1】 ...

铁佛  金牌会员 | 2024-12-26 23:52:44 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 877|帖子 877|积分 2631

下面是项目级完整配置1➡eslint:【吐血分享,博主踩过的坑你跳已往!!跳不外去?太太过了给博主打钱】
  浏览器自动打开项目:

你想开释双手吗?你想天天早上打开电脑运行完项目自动在浏览器打开吗?不要9998,不要998,只要你在我们爱的 package.json 中配置一下即可体现。如下图所示:

是的没错,只需添加 "dev": "vite --open", 包你美梦成真。
配置eslint:

是谁以前在vue.config.js内里偷偷的添加lintOnSave: false 关闭eslint检查逃过n节 ,是你吗我的先生女士们。。是我!(扭曲)(爬行)(尖叫)由于eslint太烦了!!
但是eslint可以资助我们检查js语法及少部门格式问题。 自从和我的同事(他有代码洁癖)一起工作之后,我发现我被迫改了很多…非常感谢你,和我一起练习的同事,由于有你,代码更规范~~~
eslint官网直达路线
安装eslint:

安装最新版本的eslint:

  1. pnpm i eslint -D
复制代码
告诉eslint,你要怎么工作:

  1. npx eslint --init
复制代码

我们用eslint 检查语法、发现错误,如下图选择:

我们的项目采用的js模块 的模块式开发,如下图:

框架选取vue,如下图:

是否使用ts?是的。如下图:

项目运行在浏览器还是node上,我们选择浏览器。如下图:

使用eslint去校验我们的vue、ts语法,需要安装它提示的三个插件,是否选择安装呢?是的。如下图:

使用什么包管理工具下载呢?我这里使用的是pnpm,根据自己选择哈。如下图:

安装乐成如下图(安装乐成会自动生成eslint.config.js):

安装其他版本的eslint:

but 我这次需要安装v8.x的 制止我的一些版本冲突问题哈,根据自己的需求选择。
  1. pnpm install eslint@8.57.1 --save-dev
复制代码

安装插件指令供配置:

  1. pnpm install -D eslint-plugin-import eslint-plugin-vue eslint-plugin-node eslint-plugin-prettier eslint-config-prettier eslint-plugin-node @babel/eslint-parser
复制代码
在根目录下创建 .eslintrc.cjs 文件,并配置它:

  1. // @see: http://eslint.cn
  2. module.exports = {
  3.   root: true,
  4.   env: {
  5.     browser: true,
  6.     node: true,
  7.     es6: true
  8.   },
  9.   // 指定如何解析语法
  10.   parser: "vue-eslint-parser",
  11.   // 优先级低于 parse 的语法解析配置
  12.   parserOptions: {
  13.     parser: "@typescript-eslint/parser",
  14.     ecmaVersion: 2020,
  15.     sourceType: "module",
  16.     jsxPragma: "React",
  17.     ecmaFeatures: {
  18.       jsx: true
  19.     }
  20.   },
  21.   // 继承某些已有的规则
  22.   extends: ["plugin:vue/vue3-recommended", "plugin:@typescript-eslint/recommended", "plugin:prettier/recommended"],
  23.   /**
  24.    * "off" 或 0    ==>  关闭规则
  25.    * "warn" 或 1   ==>  打开的规则作为警告(不影响代码执行)
  26.    * "error" 或 2  ==>  规则作为一个错误(代码不能执行,界面报错)
  27.    */
  28.   rules: {
  29.     // eslint (http://eslint.cn/docs/rules)
  30.     "no-var": "error", // 要求使用 let 或 const 而不是 var
  31.     "no-multiple-empty-lines": ["error", { max: 1 }], // 不允许多个空行
  32.     "prefer-const": "off", // 使用 let 关键字声明但在初始分配后从未重新分配的变量,要求使用 const
  33.     "no-use-before-define": "off", // 禁止在 函数/类/变量 定义之前使用它们
  34.     // typeScript (https://typescript-eslint.io/rules)
  35.     "@typescript-eslint/no-unused-vars": "error", // 禁止定义未使用的变量
  36.     "@typescript-eslint/no-empty-function": "error", // 禁止空函数
  37.     "@typescript-eslint/prefer-ts-expect-error": "error", // 禁止使用 @ts-ignore
  38.     "@typescript-eslint/ban-ts-comment": "error", // 禁止 @ts-<directive> 使用注释或要求在指令后进行描述
  39.     "@typescript-eslint/no-inferrable-types": "off", // 可以轻松推断的显式类型可能会增加不必要的冗长
  40.     "@typescript-eslint/no-namespace": "off", // 禁止使用自定义 TypeScript 模块和命名空间
  41.     "@typescript-eslint/no-explicit-any": "off", // 禁止使用 any 类型
  42.     "@typescript-eslint/ban-types": "off", // 禁止使用特定类型
  43.     "@typescript-eslint/no-var-requires": "off", // 允许使用 require() 函数导入模块
  44.     "@typescript-eslint/no-non-null-assertion": "off", // 不允许使用后缀运算符的非空断言(!)
  45.     "@typescript-eslint/no-require-imports": "off",
  46.     // vue (https://eslint.vuejs.org/rules)
  47.     "vue/script-setup-uses-vars": "error", // 防止<script setup>使用的变量<template>被标记为未使用,此规则仅在启用该 no-unused-vars 规则时有效
  48.     "vue/v-slot-style": "error", // 强制执行 v-slot 指令样式
  49.     "vue/no-mutating-props": "error", // 不允许改变组件 prop
  50.     "vue/custom-event-name-casing": "error", // 为自定义事件名称强制使用特定大小写
  51.     "vue/html-closing-bracket-newline": "error", // 在标签的右括号之前要求或禁止换行
  52.     "vue/attribute-hyphenation": "error", // 对模板中的自定义组件强制执行属性命名样式:my-prop="prop"
  53.     "vue/attributes-order": "off", // vue api使用顺序,强制执行属性顺序
  54.     "vue/no-v-html": "off", // 禁止使用 v-html
  55.     "vue/require-default-prop": "off", // 此规则要求为每个 prop 为必填时,必须提供默认值
  56.     "vue/multi-word-component-names": "off", // 要求组件名称始终为 “-” 链接的单词
  57.     "vue/no-setup-props-destructure": "off" // 禁止解构 props 传递给 setup
  58.   }
  59. };
复制代码
根目录创建.eslintignore文件:

  1. *.sh
  2. node_modules
  3. *.md
  4. *.woff
  5. *.ttf
  6. .vscode
  7. .idea
  8. dist
  9. /public
  10. /docs
  11. .husky
  12. .local
  13. /bin
  14. /src/mock/*
  15. stats.html
复制代码
在package.json文件中添加如下代码:

  1. "lint": "eslint src",
  2. "fix": "eslint src --fix",
复制代码

测试一下eslint的效果:


fine!

自动修补了,有点意思啊eslint你小子
so,在运行前甚至都可以先 pnpm run lint --fix 了 (★ ω ★)

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

铁佛

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表