做一个极简 UI 库之代码 lint

news2024/11/17 19:49:32

eslint, prettier, stylelint 的配置

这三个规则的配置思路:代码美化用 prettier,逻辑代码用 eslint 校验,样式代码用 stylelint 校验。有跟代码美化冲突的以 prettier 为主

为什么要用这么多呢,因为 eslint 不能解析样式代码,所以需要 stylelint,虽然可以给 eslint 配置 prettier 的规则,但是像 json,css 等文件却没办法美化,所以 prettier 的优势就突出来了,它能够保证不同文件的样式都一致

eslint

// .eslintrc.js
module.exports = {root: true,plugins: ["prettier"],extends: ["eslint:recommended","plugin:@typescript-eslint/recommended","plugin:vue/vue3-recommended","plugin:prettier/recommended",],parser: "vue-eslint-parser",rules: {"prettier/prettier": ["warn"],},parserOptions: {parser: "@typescript-eslint/parser",sourceType: "module",},
}; 

大概规则解释:使用 eslint,typescript,vue3,prettier 的推荐配置,并且按照从下往上的顺序覆盖其他规则。

parser: 这个用了 vue 的,以此来解析 .vue 的代码, 并且设置 ts 代码解析器为 @typescript-eslint/parser

prettier

这个比较简单,我直接用的 prettier 的推荐配置

stylelint

// .stylelintrc.js
module.exports = {extends: ["stylelint-config-recess-order","stylelint-config-recommended-scss","stylelint-config-recommended-vue","stylelint-config-tailwindcss","stylelint-config-prettier",],
}; 

大概规则解释(* 替换 stylelint-config):使用 -recess-order 来规定样式文件如何排序,-recommended-{scss, vue} 来提供 .scss 和 .vue 文件的解析能力。-tailwindcss 来规避我使用的 tailwindcss 造成的一些规则冲突,-prettier 来关闭跟 prettier 样式美化的规则

vscode 配置

目标:保证有 lint 错误的时候能够标红提示,保存代码时自动执行 prettier 命令来美化代码

// .vscode/settings.json
{// 默认格式化插件:esbenp.prettier-vscode"editor.defaultFormatter": "esbenp.prettier-vscode","editor.formatOnSave": true, // 每次保存的时候进行格式化"editor.codeActionsOnSave": {"source.fixAll.eslint": false, // 每次保存的时候不进行 eslint 处理},"stylelint.enable": true, // 启用 stylelint 插件"prettier.enable": true, // 启用 prettier 插件"css.validate": false, // // 关闭 vscode 默认自带的 css 检查
} 

用到的插件

// .vscode/extensions.json
{"recommendations": ["dbaeumer.vscode-eslint", // eslint 校验插件"bradlc.vscode-tailwindcss", // tailwindcss 智能提示和检查插件"heybourn.headwind", // 能够自动对 tailwindcss 的 class 变量进行排序"esbenp.prettier-vscode", // prettier 格式化插件"stylelint.vscode-stylelint", // stylelint 校验插件"Vue.volar", // vue 代码高亮,智能提示插件"ZixuanChen.vitest-explorer", // vitest 插件]
} 

这个 id 是这样得来的:

需要注意的坑

1.prettieer 和 tsconfig 这俩个配置文件的更改并不能直接生效。需要重启一下 vscode

小技巧

1.让多个配置文件折叠显示, 在 .vscode/setting 中添加如下命令

{"explorer.fileNesting.patterns": {"package.json": "stylelint.config.js, .gitignore, ...","README.md": "CHANGELOG.md, LICENCE"},
} 

2.快速重启vscode

3.查看 vscode 执行的各种命令,比如查看 git 的执行命令

husky 和 lint-stated

目标:每次提交的代码都是通过 eslint stylelint 校验的

husky 一个流行的添加 git hooks 的插件,lint-stated 智能的对 git 中暂存的代码执行相应的操作

// .lintstagedrc.js
module.exports = {"*.{js,ts,jsx,tsx}": ["eslint --fix"],"*.{vue}": ["stylelint --fix", "eslint --fix"],"*.{scss, css, less}": ["stylelint --fix", "prettier --write"],"*.{json, md}": ["prettier --write"],
}; 

lint-stated 默认是并行执行的,为了防止冲突,我对不同后缀的文件设置了不同的命令,并且防止同一个文件多次执行相同的命令

vitest 和 vite

/// <reference types="vitest" />
export default defineConfig({plugins: [vue(), vueJsx()],build: {lib: {entry: "./src/components/ToastMessage.vue",name: "index",},},test: {environment: "happy-dom",},
}); 

打包用的 vite,测试工具用的 vitest,这样可以使用相同的配置文件

总结

一个好的项目离不开一整套的前端工程化工具,而常见的代码校验相关的就是 eslint prettier stylelint husky lint-stated。这些工具只要理解了,对于后面的代码维护能够起到极大地作用,而且每个项目都可以用到,一次学习处处应用,好处多多。

最后

为大家准备了一个前端资料包。包含54本,2.57G的前端相关电子书,《前端面试宝典(附答案和解析)》,难点、重点知识视频教程(全套)。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构---LRU算法

LRU算法哈希链表自己的JAVA实现LRU全称Least Recently Used&#xff0c;也就是 最近最少使用的意思&#xff0c;是一种内存管理算法&#xff0c;该算法最早应用于Linux操作系统。这个算法基于一种假设&#xff1a;长期不被使用的数据&#xff0c;在未来被用到的几率也不大。因此…

【LeetCode】1754. 构造字典序最大的合并字符串

构造字典序最大的合并字符串 题目描述 给你两个字符串 word1 和 word2 。你需要按下述方式构造一个新字符串 merge &#xff1a;如果 word1 或 word2 非空&#xff0c;选择 下面选项之一 继续操作&#xff1a; 如果 word1 非空&#xff0c;将 word1 中的第一个字符附加到 mer…

node.js+uni计算机毕设项目基于微信小程序校园生活管理LW(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置&#xff1a; Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等…

基于形态学处理的不规则形状图像的几何参数统计,包括输出面积,周长,圆度,矩形度,伸长度

up目录 一、理论基础 二、核心程序 三、测试结果 一、理论基础 形态学是图像处理中应用最为广泛的技术之一&#xff0c;主要用于从图像中提取对表达和描绘区域形状有意义的图像分量&#xff0c;使后续的识别工作能够抓住目标对象最为本质的形状特征&#xff0c;如边界和连通…

C#语言实例源码系列-实现文件分割和合并

专栏分享点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册 &#x1f449;关于作者 众所周知&#xff0c;人生是一个漫长的流程&#xff0c;不断克服困难&#xff0c;不断反思前进的过程。在这个过程中…

腾讯云轻量应用服务器使用 WooCommerce 应用镜像搭建电商独立站

WooCommerce 是当前很受欢迎的电商独立站建站工具&#xff0c;具备开源、免费、使用简单且功能强大等特点&#xff0c;您可通过该镜像快速搭建基于 WordPress 的电商独立站。该镜像已预装 WordPress&#xff08;包含 WooCommerce 插件&#xff09;、Nginx、MariaDB、PHP 软件。…

数据结构之排序【直接选择排序和堆排序的实现及分析】内含动态演示图

文章目录引言&#xff1a;1.直接选择排序2.堆排序3.直接选择排序和堆排序的测试引言&#xff1a; 感觉今天更冷了&#xff0c;码字更加的不易&#xff0c;所以引言就简单的写一下啦&#xff01;今天我们就来了解一下什么是直接选择排序和堆排序。 1.直接选择排序 时间复杂度…

RabbitMQ 第一天 基础 4 RabbitMQ 的工作模式 4.1 Work queues 工作队列模式

RabbitMQ 【黑马程序员RabbitMQ全套教程&#xff0c;rabbitmq消息中间件到实战】 文章目录RabbitMQ第一天 基础4 RabbitMQ 的工作模式4.1 Work queues 工作队列模式4.1.1 模式说明4.1.2 代码编写4.1.3 小结第一天 基础 4 RabbitMQ 的工作模式 4.1 Work queues 工作队列模式 …

ELK第四讲之【docker安装Logstash8.4.3、集成springboot】

docker安装elasticsearch8.4.3 docker安装kibana8.4.3 一、docker安装logstash8.4.3 官方地址 https://github.com/elastic/logstash/releases 1、拉取镜像 docker pull elastic/logstash:8.4.3 2、启动容器 docker run -it -d --name logstash -p 9600:9600 -p 5044:…

十六、Docker Compose容器编排第一篇

1、概述 Compose 是一个用于定义和运行多容器 Docker 应用程序的工具。使用 Compose&#xff0c;您可以使用 YAML 文件来配置应用程序的服务。然后&#xff0c;使用一个命令&#xff0c;您可以从您的配置中创建并启动所有服务。 Compose 适用于所有环境&#xff1a;生产、暂存、…

node.js+uni计算机毕设项目高校自习室座位网上预约小程序(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置&#xff1a; Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等…

获取淘宝价格区间l-r的商品a的详细信息(商品名等)

看了一眼&#xff0c;上次更新距今2个月&#xff0c;看起来我好咕咕啊&#xff08;感叹&#xff09;&#xff0c;可是感觉这两个月也没闲着捏&#xff08;比赛&#xff0c;cf&#xff0c;期末等等&#xff0c;幸亏期末考延期了&#xff0c;我这被期末作业都整死了快&#xff09…

SpringBoot+Vue项目艺术摄影预约系统设计与实现

文末获取源码 开发语言&#xff1a;Java 使用框架&#xff1a;spring boot 前端技术&#xff1a;JavaScript、Vue.js 、css3 开发工具&#xff1a;IDEA/MyEclipse/Eclipse、Visual Studio Code 数据库&#xff1a;MySQL 5.7/8.0 数据库管理工具&#xff1a;phpstudy/Navicat JD…

Python pandas有几千个库函数,你用过几个?(2)

上一篇链接&#xff1a; Python pandas有几千个库函数&#xff0c;你用过几个&#xff1f;&#xff08;1&#xff09;_Hann Yang的博客-CSDN博客 I~Q&#xff1a; Function10~25 Types[Function][9:25] [infer_freq, interval_range, isna, isnull, json_normalize, lreshap…

微信HOOK 协议接口 实战开发篇 1.登录

使用HOOK也有不短的时间&#xff0c;写的各类接口杂乱无章 于是便有了将所有接口重构&#xff0c;整理一下的想法 顺手将整理的要点作为日志记录下来 预计每类接口写一篇日志&#xff0c;本次使用的是2022.12.24&#xff0c;当前微信最新版3.8.1.26版 言归正传&#xff0c;开始…

【秋招总结】双非本小菜鸡的坎坷秋招之路(附面经)

前言 因为大环境的影响&#xff0c;今年秋招hc骤缩&#xff0c;导致竞争的激烈程度比往年高了不少。 在秋招的时候&#xff0c;经历过简历石沉大海的无奈&#xff0c;也体验过人家收割offer而自己却依旧0offer的焦虑&#xff0c;不过好在最终也拿到了还算满意的结果。 如今我…

python爬虫把数据保存到csv、mysql中

啧&#xff0c;放假几天游戏玩腻了&#xff0c;啥都不想干&#xff0c;突然想起来python这玩意&#xff0c;无聊就来玩玩 目录 先是保存csv里面 然后保存到mysql里 目标&#xff1a;起点 主要是拿到这几个数据 分析下网页 一个li对应一本小说&#xff0c;打开li看里面的东西 …

Android ViewPager2 实现阅读器横向翻页效果(三)--- 实时动态分页及章节切换效果的原理及实现

文章目录Android ViewPager2 实现阅读器横向翻页效果&#xff08;三&#xff09;--- 实时动态分页及章节切换效果的原理及实现关键概念引入初始数据准备ViewPager Adapter 动态分页 及 第一次分页分页后更新窗口 及 首页尾页的特殊处理翻页状态监听 及 动态章节切换Android Vie…

BIT.4 Linux进程控制

目录进程创建fork函数初识写实拷贝fork常规用法fork调用失败的原因补充知识进程终止进程退出场景进程常见退出方法exit函数与_exit函数return 退出补充知识进程等待进程等待必要性进程等待的方法wait方法waitpid方法wait / waitpid 阻塞代码WIFEXITEDwait / waitpid 非阻塞代码…

LeetCode刷题复盘笔记—一文搞懂动态规划之718. 最长重复子数组问题(动态规划系列第三十一篇)

今日主要总结一下动态规划的一道题目&#xff0c;718. 最长重复子数组 题目&#xff1a;718. 最长重复子数组 Leetcode题目地址 题目描述&#xff1a; 给两个整数数组 nums1 和 nums2 &#xff0c;返回 两个数组中 公共的 、长度最长的子数组的长度 。 示例 1&#xff1a; …