如何在本地环境运行 react 源码仓库
May-26 · 10min
fork 官方仓库 facebook/react (opens in a new tab)
通常开源的项目里都有一个 CONTRIBUTING.md (opens in a new tab) 文件,来让其他的开发者知道如何贡献这个项目,或者看这个项目的 .github/workflows (opens in a new tab) 里的一些运行测试、发布的 action 都可以找到运行这个项目的有效信息
本地下载克隆的仓库
VSCode 环境
使用 VSCode 打开
插件
因为 react 是使用 flow (opens in a new tab) 语言(类似 ts )写的所以需要在 VSCode 提供相关语言的支持在 VSCode 中下载 flow 语言的插件 flow-for-vscode (opens in a new tab)
设置
在本地的打开的仓库的根目录创建下面这个文件
解释一下这里的配置,前两个是禁用默认的 js ts 检查,然后开启 flow 插件,并且使用 node_modules
下的 flow 运行,这两个其实是默认开启的,更多详细的配置 flow-for-vscode#configuration (opens in a new tab)
本机环境
这里可以直接参考 contribution-prerequisites (opens in a new tab) 的官方文档,但是有几个需要注意的地方
.nvmrc
里对应的 node 版本,最好安装对应的版本package.json
的packageManager
有对应的 yarn 版本- java 环境没有明确说什么版本,我这里安装的是
java 17.0.11 2024-04-16 LTS
- gcc 环境
安装依赖,环境检查
这里可以参考文档的这一部分 sending-a-pull-request (opens in a new tab)
完全使用 yarn.lock
安装,这里推荐一个好用的工具 antfu-collective/ni (opens in a new tab) 直接使用 nci
安装,我也参考别人的项目写了一个 rust 的版本 Debbl/nci (opens in a new tab)
因为我使用的是 M1 芯片,在安装的过程中遇到了几个问题
/bin/sh: autoreconf: command not found
使用 brew 安装brew install autoconf
- 如果上一步是使用 brew 安装的会遇到一个问题 error-cant-exec-aclocal-with-homebrew-installed-autoreconf-on-mac (opens in a new tab) 需要安装
brew install automake
optipng-bin
依赖报错,可以看这个 optipng-bin/issues/117 (opens in a new tab)
配置 flow 环境
这里直接运行这个命令会要求选择对应的环境
这里使用 dom-node
环境
执行完成之后会发现在根目录多了一个 .flowconfig
文件
检查 flow 有没有生效
完成之后 VSCode 就会有提示了
测试,本地运行
本地运行打包好的 react
这里注意 node 环境的话需要 link 三个仓库 react
react-dom
scheduler
也可以直接使用 fixtures
目录的环境,这里我使用 fixtures/packaging/webpack/dev
这里需要替换一下 input.js
文件,新版 ReactDom 里没有 render 函数了
使用 LiveServer (opens in a new tab)打开 fixtures/packaging/webpack/dev/index.html