Project Icon

million

高效优化 React 组件性能的工具

Million.js 是一款优化 React 应用性能的工具,通过改进虚拟 DOM 实现,可将组件速度提升至多 70%。它无缝集成于现有 React 项目,减少渲染开销,帮助开发者实现接近原生 JavaScript 的运行效率,同时保留 React 的开发优势。

想要自动查找和修复性能问题吗?试试 Million Lint

Million.js 横幅

Million.js 是什么?

Million.js 是一个极快且轻量的优化编译器,可以使组件的性能提升最高 70%

哦,天哪...又一个 /virtual dom|javascript/gi 框架?我对 React 已经很满意了,为什么我还需要这个?

Million.js 可以与 React 配合使用,并使协调过程更快。通过使用经过精心调优的优化虚拟 DOM,Million.js 减少了差异比较的开销(在这里试试看

简而言之: 想象一下 React 组件以原生 JavaScript 的速度运行。

👉 几秒钟内设置 Million.js!→

安装

Million.js CLI 将自动为你安装软件包并配置项目。

npx million@latest

安装完成后,只需运行你的项目,相关信息就会显示在命令行中!

安装遇到问题?→ 查看安装指南

为什么选择 Million.js?

要理解为什么使用 Million.js,我们需要了解 React 如何更新界面。当应用程序的状态或属性发生变化时,React 会进行两个部分的更新:渲染和协调。

为了说明这一点,假设这是我们的 App

function App() {
  const [count, setCount] = useState(0);
  const increment = () => setCount(count + 1);
  return (
    <div>
      <p>计数:{count}</p>
      <button onClick={increment}>递增</button>
    </div>
  );
}

在这个 App 中,当我点击按钮时,count 状态会更新,<p> 标签也会更新以反映新的值。让我们来分解一下这个过程。

渲染

第一步是渲染。渲染是生成当前组件快照的过程。你可以想象它就像简单地"调用" App 函数并将输出存储在一个变量中。这就是 App 快照的样子:

const snapshot = App();

// snapshot =
<div>
  <p>计数:1</p>
  <button onClick={increment}>递增</button>
</div>;

协调

为了更新界面以反映新的状态,React 需要比较前一个快照和新快照(称为"差异比较")。React 的协调器会遍历前一个快照中的每个元素,并将其与新快照进行比较。如果元素相同,它会跳过;如果元素不同,它会更新。

  • <div> 标签相同,所以不需要更新。✅
    • <p> 标签相同,所以不需要更新。✅
      • <p> 标签内的文本不同,所以需要更新。⚠️
    • <button> 标签相同,所以不需要更新。✅
      • onClick 属性相同,所以不需要更新。✅
      • <button> 标签内的文本相同,所以不需要更新。✅

(总共:6 次差异检查)

<div>
-  <p>计数:0</p>
+  <p>计数:1</p>
  <button onClick={increment}>递增</button>
</div>

从这里我们可以看到,<p> 标签需要更新。然后 React 将更新 <p> DOM 节点以反映新的值。

<p>.innerHTML = `计数:${count}`;

Million.js 如何使这个过程更快

React 很慢。

React 协调的问题在于,随着 JSX 元素数量的增加,它的速度会指数级下降。对于这个简单的 App,它只需要对几个元素进行差异比较。但在真实的 React 应用中,你很容易有数百个元素,这会减慢界面更新的速度。

Million.js 通过完全跳过差异比较步骤并直接更新 DOM 节点来解决这个问题。

以下是 Million.js 协调器工作原理的概念示例:

function App() {
  const [count, setCount] = useState(0);
  const increment = () => setCount(count + 1);

  // 由编译器生成
  if (count !== prevCount) {
    <p>.innerHTML = `计数:${count}`;
  }

  <button>.onclick = increment;

  // ...
}

请注意,当"count"更新时,Million.js 将直接更新 DOM 节点。Million.js 将 React 协调的时间复杂度从 O(n)(线性时间)转变为 O(1)(常数时间)。

它有多快?→ 查看基准测试

资源与贡献

寻找文档?请查看文档贡献指南。我们还建议阅读Virtual DOM: Back in Block以了解更多关于 Million.js 的内部原理。

想与社区交流?加入我们的 Discord,分享你的想法和用 Million.js 构建的项目。

发现 bug?请前往我们的问题追踪器,我们会尽力提供帮助。我们也非常欢迎 pull requests!

我们希望所有 Million.js 贡献者都遵守我们的行为准则

→ 在 GitHub 上开始贡献

Alt

代码库

这个仓库是一个包含多个模块的"单体仓库"。Million.js 作为一个 NPM 包发布,但对更复杂且重要的扩展提供一流的模块支持。每个模块在 /packages 目录下都有自己的文件夹。

你也可以通过我们的路线图跟踪我们的进展。

模块描述
million包含 Million.js 核心的主要虚拟 DOM。
react / react-serverMillion.js 的 React 兼容性。
compilerMillion.js 在 React 中的编译器。
jsx-runtimeMillion.js 核心的简单 JSX 运行时。
types包间共享的类型

赞助商

致谢

Million.js 深受以下项目的启发:

许可证

Million.js 是由 Aiden Bai贡献者们开发的 MIT 许可的开源软件:

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号