1.React 组件库都是打打包怎么打包的?
2.ant打包工具
React 组件库都是怎么打包的?
组件库在业界广泛应用,例如阿里的包源 ant-design、字节的原理 semi-design 和 arco-design 等。
但您是打打包否好奇,这些组件库是包源如何进行打包的呢?若您自己创建组件库,应该如何编写打包逻辑呢?本文将为您解答。原理相册专辑源码
我们可以创建一个新的打打包项目,并分别安装 ant-design、包源arco-design 和 semi-design。原理npm 或 yarn 会铺平所有依赖,打打包而 pnpm 则能保持 node_modules 目录的包源清晰。
以 antd 为例,原理它分为 lib、打打包es 和 dist 三个目录,包源MIYOU源码系统分别存放着不同规范的原理组件代码。
lib 目录下的组件使用 commonjs 规范,es 目录下的组件使用 es module 规范,而 dist 目录下的组件则使用 umd 规范。
在 package.json 文件中,antd 分别声明了 commonjs、esm、umd 和类型的入口。这意味着,使用 require 引入的是 lib 目录下的组件,而使用 import 引入的是 es 目录下的组件。
接下来,让我们看看 semi-design 和 arco-design 的予曦源码打包方式,它们同样分为 lib、es 和 dist 三个目录,并分别声明了 esm、commonjs 和 umd 的入口。
若您有一个 esm 模块,如何构建出 esm、commonjs 和 umd 的代码呢?答案很简单,umd 代码使用 webpack 打包,而 esm 和 commonjs 则只需使用 tsc 或 babel 编译即可。
让我们以 arco-design 为例,其打包逻辑位于 arco-cli 的 arco-scripts 目录下。index.ts 文件中包含了编译三种代码和构建 CSS 的方法。
对于 esm 和 cjs,青果视频源码编译方法封装了一个 compileTS 方法,传入不同的类型进行编译。编译过程中,可以使用 tsc 或 babel。
对于 umd,使用 webpack 进行打包,配置文件中使用了 ts-loader 和 babel-loader,而 CSS 部分则使用 less 进行编译。
同样,semi-design 也使用 gulp 组织编译任务,编译 esm 和 cjs 代码使用 tsc 和 babel,而 umd 代码则使用 webpack 打包。
总结来说,unity旅游源码虽然三个组件库在具体实现上存在一些差异,但它们的编译打包逻辑基本相同,都是通过构建出 esm、commonjs 和 umd 代码,并在 package.json 中声明不同模块规范的入口。
编译打包并非组件库的难点,掌握相关工具和库后,您可以轻松实现自己的组件库打包逻辑。
ant打包工具
Ant工具是一种基于Java的构建工具,类似于Unix中的make,但具有改进的特性。Ant 1.9.0是当前的最新版本。 尽管make、gnumake、nmake等工具存在,Ant的创建初衷是因为其原作者在开发过程中对这些工具的局限性和不便感到困扰。传统的基于shell的工具如make,虽然可以通过扩展OS特定命令扩展功能,但这也限制了其跨平台性。Makefile的问题,如tab敏感性,也让Ant的开发者深感不便。 Ant则采取了不同的扩展方式,使用Java类而非shell命令,构建文件是基于XML格式的target树,每个task由实现了Task接口的Java类执行。即使初学者对Ant不熟悉,也可以在需要时回溯相关介绍。Ant的优势在于,它提供了跨平台的能力,允许在任何环境下工作,而通过 task执行特定OS命令。 Ant的使用场景主要在于大型项目,如编译、打包、测试等重复性工作。Ant脚本,如build.xml,定义了一系列任务,如清理、编译、生成文档和打包等,这些任务之间有明确的依赖关系。例如,打包任务依赖于编译,而编译任务又依赖于环境初始化。 Ant文件的结构包括元素,定义项目属性;元素,表示可执行的目标和依赖关系;、、、等标签,分别用于创建目录、打包、编译和执行Java程序。Ant还支持自定义任务,通过、、、等元素灵活配置。 Ant的优点包括跨平台性、易于操作和维护,以及与开发环境的集成。安装Ant后,只需在命令行中切换到项目目录并运行ant命令,Ant会查找并执行build.xml中的默认任务或指定任务。 最后,Apache Ant 1.9于年3月日发布,标志着Ant工具的持续更新和完善。