【从0实现React18】 (一) 项目初始化

Multi-repo 和 Mono-repo

由于需要同时管理多个包 ,如React、React-dom等,所以选择**Mono-repo**

选择使用pnpm-workspace搭建Mono-repo环境的原因

  • 依赖安装快
  • 更规范

Pnpm初始化

npm install -g pnpm
pnpm init

配置pnpm-workspace.yml文件

pnpm-workspace.yaml 文件:

packages:
  # all packages in direct subdirs of packages/
  - 'packages/*'

定义开发规范

eslint安装配置

安装

pnpm i eslint -D -w

初始化

npx eslint --init

配置

pretiier 安装配置

安装

pnpm i prettier -D -w

prettier继承到eslint

pnpm i eslint-config-prettier eslint-plugin-prettier -D -w

为lint添加对应的执行脚本

"lint": "eslint --ext .ts,.jsx,.tsx --fix --quiet ./packages"

commit规范检查

husky

安装husky,用于拦截comiit命令

pnpm i husky -D -w

初始化husky

pnpm husky init

将刚才实现的lint命令纳入comiit时husky将执行的脚本

echo "pnpm lint" > .husky/pre-commit

commitlint

安装commitLint

pnpm i commitlint @commitlint/config-conventional @commitlint/cli -D -w

新建配置文件.commitlintrc.js

echo "export default { extends: ['@commitlint/config-conventional'] };" > commitlint.config.js

集成到husky

echo "pnpm dlx commitlint --edit $1" > .husky/commit-msg

打包工具

使用rollup打包

pnpm i -D -w rollup
相关推荐
老华带你飞7 分钟前
公寓管理系统|SprinBoot+vue夕阳红公寓管理系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·课程设计
gopher951124 分钟前
HTML详解
前端·html
Tiny201725 分钟前
前端模块化CommonJs、ESM、AMD总结
前端
吕永强27 分钟前
CSS相关属性和显示模式
前端·css·css3
结衣结衣.32 分钟前
python中的函数介绍
java·c语言·开发语言·前端·笔记·python·学习
全栈技术负责人33 分钟前
前端提升方向
前端
赵锦川33 分钟前
css三角形:css画箭头向下的三角形
前端·css
qbbmnnnnnn38 分钟前
【WebGis开发 - Cesium】如何确保Cesium场景加载完毕
前端·javascript·vue.js·gis·cesium·webgis·三维可视化开发
f8979070702 小时前
layui动态表格出现 横竖间隔线
前端·javascript·layui
鱼跃鹰飞2 小时前
Leecode热题100-295.数据流中的中位数
java·服务器·开发语言·前端·算法·leetcode·面试