前端正在被“锈”化

jeff Atwood 在 2007 年说:"any application that can be writen in JavaScript , willeventually be written in JavaScript",翻译过来就是:“任何可以使用 JavaScript 来编写的应用,并最终也会由 JavaScript 编写”,也被称为:Atwood定律。2024 回过头看看,正如他所讲那样 JavaScript 语言遍地开花。但是随着前端扮演角色越来越重要,JavaScript 由于是单线程从而导致性能问题也暴露出来,webpack 打包慢,项目上 ESLint + Prettier后卡死等等。可以看到天下苦 JavaScript 性能差久已。于是 Rust 也就顺势而上了,目前前端基建领域基本上都被“锈”化了一遍,今天我们就来看看被“锈”化的 ESLint + Prettier ,Biome

初识 Biome

在认识 Biome 之前,先聊聊为什么要了解它,也就是 ESLint 和 Prettier 的问题:

  • ESLint + Prettier 的组合需要维护多个配置文件

  • 传统工具的性能问题,特别是在大型项目中

  • 工具之间的配置冲突

  • 环境依赖复杂

我们再来看看“锈”化后的代码格式化工具 Biome:

  1. 极致的性能:由 Rust 编写,比传统工具快 35 倍

  2. 简单的配置:零配置即可使用,无需复杂设置

  3. 一体化方案:将格式化和代码检查集成在一个工具中

  4. 兼容性强:与 Prettier 有 97% 的兼容性

  5. 支持多种语言:支持 JavaScript、TypeScript、JSX、JSON、CSS 和 GraphQL

简直可以说是“降维打击”,知道了 why,我们看看 Biome 是个 what?其实 Biome 还有一个彩蛋,我们下面讲

带着好奇和憧憬的心情,我搜索到了 Biome 的官网:https://biomejs.dev/ 。官网上是这样介绍的: web 项目的一个工具链,谈笑间即可完成格式化和 lint 等操作。我只能说 Biome 是懂吊胃口的。必须学啊!

它提供了 playground :https://biomejs.dev/playground/ 。但是需要吐槽的是明明有中文入口,但是 404:

image-20241222162854025

简单体验了一下感觉还是可以的,但是 playground 是游乐场啊,行不行还是要去项目里看看的

image-20241222163042597

image-20241222163042597

在去之前,还是先看看人家官方还说了哪些:

  • 像 Prettier 一样格式化代码,但是节省了时间

  • 修复问题,Biome 输出更加详细更加场景化的诊断

  • 一个命令,就搞定 Eslint + Prettier

  • 默认集成了社区的最佳实践

等等好处,我们赶快试试吧!

体验 Biome

使用 Biome 大多数是两个场景:

  1. 搭建一个新项目,集成 Biome,抛弃 ESLint + Prettier

  2. 已经有的项目替换 Biome 为格式化和代码检查工具

我们一个个来体验,先看新项目如何集成:

新项目集成 Biome

我们使用 vite 的脚手架创建一个新的 react 项目, 创建成功后,我们去 package.json 把 eslint + prettier 相关的依赖删除,这样项目就没有 Prettier 和 ESLint 的。

image-20241222165750217

image-20241222165750217

我们同时关闭编辑器的 eslint 和 prettier 插件,我们去修改代码会发现已经不会自动格式化,不规范代码也不报错了。那太好了,接下来请我们主角登场:

pnpm i -D --save-exact @biomejs/biome 

然后运行 pnpm biome init 来初始化 biome 配置文件

image-20241222170355718

image-20241222170355718

上面说:

image-20241222170537551

image-20241222170537551

我们按照它说的做,我们可以先故意写一些不规范的代码,然后运行: npx @biomejs/biome check --apply ./src,看看 biome 会不会自动识别出来

image-20241222171006691

image-20241222171006691

结果它都正确识别出来了,人家一个工具不仅仅是干了 ESLint 的事情,还干了 Prettier 的事情(真的是工具链)。但是我们使用这俩的时候,我们会在 package.json 写好脚本,这样就不用每次在终端输入了,biome 当然也行的:

"format": "biome format --write .", // 格式化所有文件
"lint": "biome lint .", // 进行代码检查
"check": "biome check .", // 同时运行格式化和代码检查
"fix": "biome check --apply .", // 自动修复可以修复的问题
"ci": "biome ci ." // 环境中使用的检查命令

这上面写的都是什么呀!不急,我们马上学,下面我们来看看常用的 biome 命令(CLI)

  • init:项目根目录创建 biome.json 配置文件。生成的配置文件包含基本的格式化和检查规则

  • check:最全面的命令,它会同时运行格式化、代码检查和导入排序
    • --write:告诉 Biome 直接修改源文件,将格式化后的内容写入原文件

  • format:仅格式化(可理解为 Prettier)。后面可以跟目录,文件,也可以是特定类型文件(类似:"./src/**/*.{js,jsx,ts,tsx}"
    • --write:直接应用格式化

  • lint:仅代码检查(可理解为 ESLint)
    • --write:自动修复可修复的问题

  • ci:专门为 CI 环境设计,会以非交互模式运行检查

一些常用的命令行选项

# 详细输出模式
--verbose

# 指定配置文件路径
--config-path=./custom-biome.json

# 设置诊断级别
--diagnostic-level=error|warn|info

# 忽略语法错误
--skip-errors

# 修改输出格式
--reporter=json|summary|github

# 规则集选项
--rule-set recommended
# recommended 规则集包含:
# 最佳实践规则
# 常见错误检测
# 代码风格规则
# 这些规则经过 Biome 团队精心筛选和测试

我们还可以在 pre-commit 中运行pnpm biome check --write $(git diff --staged --name-only) ,来先运行 biome

老项目使用 Biome

上面图片给出的提示中,还有两个命令我们没有使用,就是

biome migrate eslint --write
biome migrate prettier --write

在老项目一般都是集成了 ESLint + Prettier 的,所以我们迁移,肯定需要兼容之前的规范的。我们可以使用这两个命令来实现,更多细节:https://biomejs.dev/zh-cn/guides/migrate-eslint-prettier/。

做完这两个事项后,我们先检查一下之前配置的规则是否都还在,如果都还是正常的,我们就可以移除 ESLint 和 Prettier 相关的依赖和配置文件了

我使用我的博客项目测试,非常好用,以后再也不怕写代码保存的时候卡死了

Biome 插件

像 ESLint 和 Prettier 一样,Biome 也有自己的编辑器插件,我们只需要搜索安装,然后

image-20241222175846141

image-20241222175846141

总结

项目配置 ESLint 和 Prettier 一大堆依赖和代码,运行 ESLint 和 Prettier 编辑器总是卡死,Biome 的出现解决了这个问题,无需任何配置,只需要安装好就可以写代码。Biome 代表了前端工具链的新方向,它通过 Rust 优秀的性能,已经受到社区的广泛喜爱。

而且 Biome 还赢得了 prettier 挑战赛的 20000 元美金,感兴趣的可以看:https://biomejs.dev/blog/biome-wins-prettier-challenge/ 。这个挑战的要求是:通过超过 95% 的 Prettier JavaScript 测试,可以看出 Biome 真的是可以信赖的,这算不算一个彩蛋哈哈!

参考

  1. 官网:https://biomejs.dev/

  2. Rust 引领前端基建新潮流:字节跳动的深度应用实践

  3. 什么是 “锈”化

  4. 使用 biome 的新项目

  5. 我的博客改为 blome 作为代码检测

  6. 和 AI 的聊天

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

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

相关文章

【Ubuntu】Ubuntu server 18.04 搭建Slurm并行计算环境(包含NFS)

Ubuntu server 18.04 搭建Slurm并行计算环境(包含NFS) 一、Munge 认证模块 1.1、安装 munge 主节点和子节点都安装munge #安装 sudo apt update && sudo apt install munge libmunge-dev#设置开机启动 sudo systemctl enable munge sudo syste…

SELECT 语句用法大全:数据库查询的核心力量

在数据库的世界中,SELECT 语句犹如一把万能钥匙,开启了数据检索的大门,让我们能够从海量的数据中精准地获取所需的信息。它的用法丰富多样,涵盖了从简单的数据查看,到复杂的数据统计和关联查询等多个方面,为…

小程序配置文件 —— 14 全局配置 - tabbar配置

全局配置 - tabBar配置 tabBar 字段:定义小程序顶部、底部 tab 栏,用以实现页面之间的快速切换;可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页面; 在上面图中,标注了一些 tabBar …

计算机网络 (8)物理层的传输方式

一、串行传输与并行传输 串行传输 定义:串行传输是一种数据传输方式,指的是逐位地按照顺序传输数据。在串行传输中,数据位逐个按照一定的顺序进行传输,可以通过单条线路或信道进行。特点: 逐位传输:串行传输…

Edge如何获得纯净的启动界面

启动Edge会出现快速链接,推广链接,网站导航,显示小组件,显示信息提要,背景 ●复杂页面 ●精简页面 点击页面设置按钮 关闭快速链接 关闭网站导航 关闭小组件 关闭信息提要 关闭背景 关闭天气提示 精简页面看起来十分舒…

细说STM32F407单片机CAN基础知识及其HAL驱动程序

目录 一、CAN总线结构和传输协议 1、 CAN总线结构 (1)闭环结构的CAN总线网络 (2)开环结构的CAN总线网络 (3)隐性电平和显性电平 2、CAN总线传输协议 (1)CAN总线传输特点 &am…

计算机的错误计算(一百九十六)

摘要 用两个大模型计算 arccos(0.444). 结果保留 4位有效数字。两个大模型的计算结果相同,并均有误差。 例1. 计算 arccos(0.444). 结果保留 4位有效数字。 下面是与一个大模型的对话。 以上为与一大模型的对话。 下面是与另一大模型的对话。 点评: &…

打印进度条

文章目录 1.Python语言实现(1)黑白色(2)彩色:蓝色 2.C语言实现(1)黑白颜色(2)彩色版:红绿色 1.Python语言实现 (1)黑白色 import sys import timedef progress_bar(percentage, width50):"""打印进度条:param percentage: 当前进度百分比…

Fiddler断点(拦截)--篡改请求后或者响应前数据

目录 一、断点介绍 图例 简单介绍: 详细介绍: 二、操作步骤 文章操作资源下载 (一)设置要抓包的地址 (二)全局拦截(断点) 1.请求后拦截(Before Request) 解开拦截 2.响应前拦截(After Responses&#xff…

【ArcGIS Pro/GeoScene Pro】可视化时态数据

可视化过去二十年新西兰国际旅游业的发展变化 工程数据下载 ArcGIS Pro 快速入门指南—ArcGIS Pro | 文档 添加数据 数据为中国旅客数据 转置表字段 列数据转行数据

【基础篇】三、MySQL表结构的操作

文章目录 Ⅰ. 创建表1、语法2、创建表样例3、创建和其它表一样结构的表 Ⅱ. 查看表结构1、查看数据库中的表2、查看指定表的属性3、获取表的创建语句 Ⅲ. 删除表Ⅳ. 修改表结构1、向表中插入新的字段2、删除表中的字段3、修改表名4、修改字段属性 Ⅰ. 创建表 1、语法 create …

小程序租赁系统开发的优势与应用探索

内容概要 在如今这个数码科技飞速发展的时代,小程序租赁系统开发仿佛是一张神奇的魔法卡,能让租赁体验变得顺畅如丝。想象一下,无论你需要租用什么,从单车到房屋,甚至是派对用品,只需动动手指,…

ArcGIS教程(009):ArcGIS制作校园3D展示图

文章目录 数据下载校园3D展示图制作创建要素类矢量化【楼】要素矢量化【绿地】矢量化【范围】矢量化处理打开ArcScene添加动画数据下载 https://download.csdn.net/download/WwLK123/90189025校园3D展示图制作 创建要素类 添加底图: 新建【文件地理数据库】,并修改名称为【…

Secured Finance 与 Parasail 在流动性质押领域开展合作

Secured Finance 宣布与 Parasail 达成战略合作,标志着生态在推进 DePIN 及人工智能生态系统能力的重要里程碑。此次合作将 Parasail 卓越的质押方案与 Secured Finance 在去中心化贷款和稳定币协议方面的专业能力相结合,为 Filecoin 生态系统内的创新金…

pytorch基础之注解的使用--003

Title 1.学习目标2.定义3.使用步骤4.结果 1.学习目标 针对源码中出现一些注解的问题,这里专门写一篇文章进行讲解。包括如何自定义注解,以及注意事项,相信JAVA中很多朋友业写过,但是今天写的是Python哦。。。 2.定义 在 Python…

!倒序数 !

时间限制:C/C 1000MS,其他语言 2000MS 内存限制:C/C 256MB,其他语言 512MB 难度:中等 分数:100 OI排行榜得分:12(0.1*分数2*难度) 描述 输入一个非负整数,输出这个数的倒序数。例如…

【Redis】Redis 典型应用 - 缓存 (cache)

目录 1. 什么是缓存 2. 使用 Redis 作为缓存 3. 缓存的更新策略 3.1 定期生成 3.2 实时生成 4. 缓存的淘汰策略 5. 缓存预热, 缓存穿透, 缓存雪崩 和 缓存击穿 关于缓存预热 (Cache preheating) 关于缓存穿透 (Cache penetration) 关于缓存雪崩 (Cache avalanche) 关…

《燕云十六声》d3dcompiler_47.dll缺失怎么解决?

一、d3dcompiler_47.dll缺失的原因 系统更新或升级:Windows系统的更新可能会更改或删除某些旧版本的DirectX组件,包括d3dcompiler_47.dll。游戏安装不完整:游戏安装过程中可能出现中断或错误,导致某些必要的文件未能正确安装。软…

RT-Thread中堆和栈怎么跟单片机内存相联系

现在RT-ThreadMCU的应用方式越来越普遍,RT-Thread需要配置MCU中的RAM到的系统中,进入系统内存管理,才能提供给基于实时系统的应用程序使用,比如给应用程序提供malloc、free等函数调用功能。在嵌入式软件开发中,我们经常…

Qt https请求报错SSL handshake failed 解决思路方法

先执行下面代码 qDebug() << manager.supportedSchemes();bool bSupp QSslSocket::supportsSsl();auto buildVersion QSslSocket::sslLibraryBuildVersionString();QString version QSslSocket::sslLibraryVersionString();qInfo() << bSupp << buildVers…