如何在本地环境运行 react 源码仓库

fork 官方仓库 facebook/react

通常开源的项目里都有一个 CONTRIBUTING.md 文件,来让其他的开发者知道如何贡献这个项目,或者看这个项目的 .github/workflows 里的一些运行测试、发布的 action 都可以找到运行这个项目的有效信息

本地下载克隆的仓库

bash 复制代码
git clone git@github.com:Debbl/react.git

VSCode 环境

使用 VSCode 打开

bash 复制代码
code react

插件

因为 react 是使用 flow 语言(类似 ts )写的所以需要在 VSCode 提供相关语言的支持在 VSCode 中下载 flow 语言的插件 flow-for-vscode

.vscode/extensions.json

json 复制代码
{
    "recommendations": [
        "flowtype.flow-for-vscode"
    ]
}

设置

在本地的打开的仓库的根目录创建下面这个文件

.vscode/settings.json

json 复制代码
{ 
    "javascript.validate.enable": false,
    "typescript.validate.enable": false,
    "flow.enabled": true,
    "flow.useNPMPackagedFlow": true
}

解释一下这里的配置,前两个是禁用默认的 js ts 检查,然后开启 flow 插件,并且使用 node_modules 下的 flow 运行,这两个其实是默认开启的,更多详细的配置 flow-for-vscode#configuration

本机环境

这里可以直接参考 contribution-prerequisites 的官方文档,但是有几个需要注意的地方

  • .nvmrc 里对应的 node 版本,最好安装对应的版本

  • package.jsonpackageManager 有对应的 yarn 版本

  • java 环境没有明确说什么版本,我这里安装的是 java 17.0.11 2024-04-16 LTS

  • gcc 环境

安装依赖,环境检查

这里可以参考文档的这一部分 sending-a-pull-request

完全使用 yarn.lock 安装,这里推荐一个好用的工具 antfu-collective/ni 直接使用 nci 安装,我也参考别人的项目写了一个 rust 的版本 Debbl/nci

bash 复制代码
yarn install --frozen-lockfile

因为我使用的是 M1 芯片,在安装的过程中遇到了几个问题

配置 flow 环境

bash 复制代码
yarn flow

这里直接运行这个命令会要求选择对应的环境

这里使用 dom-node 环境

bash 复制代码
yarn flow dom-node

执行完成之后会发现在根目录多了一个 .flowconfig 文件

检查 flow 有没有生效

完成之后 VSCode 就会有提示了

测试,本地运行

bash 复制代码
yarn test

本地运行打包好的 react

可以参考文档的 development-workflow

bash 复制代码
cd build/oss-experimental/react
yarn link

cd build/oss-experimental/react-dom
yarn link

这里注意 node 环境的话需要 link 三个仓库 react react-dom scheduler

也可以直接使用 fixtures 目录的环境,这里我使用 fixtures/packaging/webpack/dev

bash 复制代码
cd fixtures/packaging/webpack/dev

yarn

yarn build

这里需要替换一下 input.js 文件,新版 ReactDom 里没有 render 函数了

fixtures/packaging/webpack/dev/input.js

js 复制代码
var React = require('react');
var ReactDOM = require('react-dom');

ReactDOM.render(
  React.createElement('h1', null, 'Hello World!'),
  document.getElementById('container')
);
js 复制代码
var React = require('react');
var {createRoot} = require('react-dom/client');

console.log('react version:', React.version);

const root = createRoot(document.getElementById('container'));
root.render(React.createElement('h1', null, 'Hello World!'));

使用 LiveServer打开 fixtures/packaging/webpack/dev/index.html

相关推荐
LilySesy10 分钟前
ABAP+如果在join的时候需要表1的字段某几位等于表2的字段的某几位,需要怎么做?
服务器·前端·数据库·sap·abap·alv
吃饺子不吃馅44 分钟前
⚡️ Zustand 撤销重做利器:Zundo 实现原理深度解析
前端·javascript·github
幼儿园技术家1 小时前
网站在苹果 Safari 进行适配遇到的问题
前端
IT_陈寒1 小时前
7个鲜为人知的JavaScript性能优化技巧,让你的网页加载速度提升50%
前端·人工智能·后端
不坑老师1 小时前
不坑盒子的插入网页功能是完全免费的!
前端·html
Wang's Blog1 小时前
前端FAQ: 描述⼀下你最近使⽤过的前端框架,并解释为何选择它们?
前端·vue.js·faq
wgego1 小时前
做题笔记BUU (XSS-Lab)(1-14)
前端·笔记·xss
dllxhcjla2 小时前
css第二天
java·前端·css
远航_2 小时前
10 个被严重低估的 JS 特性,直接少写 500 行代码
前端·javascript
起这个名字2 小时前
感觉这篇 DeepSeek 给出的微前端实践很牛!轻喷!
前端