從零搭建react+ts組件庫(kù)(封裝antd)的詳細(xì)過(guò)程
為什么會(huì)有這樣一篇文章?因?yàn)榫W(wǎng)上的教程/示例只說(shuō)了怎么做,沒(méi)有系統(tǒng)詳細(xì)的介紹引入這些依賴、為什么要這樣配置,甚至有些文章還是錯(cuò)的!迫于技術(shù)潔癖,我希望更多的開發(fā)小伙伴能夠真正的理解一個(gè)項(xiàng)目搭建各個(gè)方面的細(xì)節(jié),做到面對(duì)對(duì)于工程出現(xiàn)的錯(cuò)誤能夠做到有把握。
最近使用阿里低開引擎的時(shí)候,想要封裝一套組件庫(kù)作為物料給低開引擎引入。根據(jù)低開引擎的物料封層模式,我的訴求是做一套組件庫(kù),并且將該組件庫(kù)以u(píng)md方式生成。當(dāng)然,從零開始開發(fā)組件庫(kù)也是一個(gè)比較耗時(shí)耗力的事情,所以我想到將antd組件封裝,于是催生出了本篇文章。
在封裝組件并生成umd代碼過(guò)程中,踩了很多的坑,也更加系統(tǒng)的了解了babel。
整體需求
- react組件庫(kù),取名r-ui,能夠?qū)С鰎-ui.umd.js和r-ui.umd.css。
- 代碼使用typescript進(jìn)行開發(fā)。
- 樣式使用less進(jìn)行開發(fā)。
- 引入antd組件庫(kù)作為底層原子組件庫(kù),并且r-ui.umd.js和r-ui.umd.css包含antd組件代碼和樣式代碼。
- 依賴的react、react-dom模塊以外部引用方式。
開發(fā)與打包工具選型
使用webpack作為打包工具
老牌而又經(jīng)典的打包工具,廣泛的使用,豐富的插件生態(tài)以及各種易得的樣例。
使用babel來(lái)處理typescript代碼
由于 TypeScript 和 Babel 團(tuán)隊(duì)官方合作了一年的項(xiàng)目:TypeScript plugin for Babel(
@babel/preset-typescript),TypeScript 的使用變得比以往任何時(shí)候都容易。 —— 摘自《TypeScript With Babel: A Beautiful Marriage (TypeScript 和 Babel:美麗的結(jié)合)》
建議各位讀者可以先閱讀一下上面的文章(有中文翻譯文章)。
使用less-loader、css-loader等處理樣式代碼
使用MiniCssExtractPlugin分離CSS
項(xiàng)目搭建思路
整體結(jié)構(gòu)
- r-ui
|- src
|- components
|- button
|- index.tsx
|- index.tsx方案思路
編寫webpack.config.js配置文件,添加核心loader:
- babel-loader。接收ts文件,交給babel-core以及相關(guān)babel插件進(jìn)行處理,得到j(luò)s代碼。
- less-loader。接收l(shuí)ess樣式文件,處理得到css樣式代碼。
- css-loader+MiniCssExtractPlugin.loader。接收css樣式代碼進(jìn)行處理,并分離導(dǎo)出組件庫(kù)樣式文件。
項(xiàng)目搭建實(shí)施
初始化
初始化r-ui項(xiàng)目
mkdir r-ui && cd r-ui && npm init # 配置項(xiàng)目基本信息(name、version......)
初始化git倉(cāng)庫(kù),添加gitignore文件(后續(xù)所有命令非特殊情況,均相對(duì)于項(xiàng)目根目錄)
git init # .gitignore文件內(nèi)容請(qǐng)直接查看項(xiàng)目?jī)?nèi)文件 # 完成后,初始提交: # git add . && git commit -m "init"
安裝webpack(包管理器使用yarn)
yarn add -D webpack webpack-cli webpack-dev-server # 安裝webpack-dev-server是為后續(xù)構(gòu)建樣例頁(yè)面做準(zhǔn)備,前期可以不安裝。
diff --git a/package.json b/package.json
index e01c1b1..53dd9a3 100644
--- a/package.json
+++ b/package.json
@@ -8,5 +8,9 @@
},
"author": "",
"license": "MIT",
- "devDependencies": {}
+ "devDependencies": {
+ "webpack": "^5.72.1",
+ "webpack-cli": "^4.9.2",
+ "webpack-dev-server": "^4.9.0"
+ }
}項(xiàng)目根目錄添加webpack.config.js并進(jìn)行初始配置
// webpack.config.js
const {resolve} = require("path");
module.exports = {
// 組件庫(kù)的起點(diǎn)入口
entry: './src/index.tsx',
output: {
filename: "r-ui.umd.js", // 打包后的文件名
path: resolve(__dirname, 'dist'), // 打包后的文件目錄:根目錄/dist/
library: 'rui', // 導(dǎo)出的UMD js會(huì)在window掛rui,即可以訪問(wèn)window.rui
libraryTarget: 'umd' // 導(dǎo)出庫(kù)為UMD形式
},
resolve: {
// webpack 默認(rèn)只處理js、jsx等js代碼
extensions: ['.js', '.jsx', '.ts', '.tsx']
},
externals: {},
// 模塊
module: {
// 規(guī)則
rules: []
}
};Babel引入
引入babel-loader以及相關(guān)babel庫(kù)
yarn add -D babel-loader @babel/core @babel/preset-env @babel/preset-typescript @babel/preset-react @babel/plugin-proposal-class-properties @babel/plugin-proposal-object-rest-spread
diff --git a/package.json b/package.json
index 53dd9a3..33c32b6 100644
--- a/package.json
+++ b/package.json
@@ -9,6 +9,13 @@
"author": "",
"license": "MIT",
"devDependencies": {
+ "@babel/core": "^7.18.2",
+ "@babel/plugin-proposal-class-properties": "^7.17.12",
+ "@babel/plugin-proposal-object-rest-spread": "^7.18.0",
+ "@babel/preset-env": "^7.18.2",
+ "@babel/preset-react": "^7.17.12",
+ "@babel/preset-typescript": "^7.17.12",
+ "babel-loader": "^8.2.5",
"webpack": "^5.72.1",
"webpack-cli": "^4.9.2",
"webpack-dev-server": "^4.9.0"
(END)了解Babel
如果對(duì)于babel不太熟悉,可能對(duì)這一堆的依賴感到恐懼,這里如果讀者有時(shí)間,我推薦這篇深入了解babel的文章:一口(很長(zhǎng)的)氣了解 babel - 知乎 (zhihu.com)。當(dāng)然,如果這口氣憋不?。ü易鲆粋€(gè)簡(jiǎn)單摘抄:
babel 總共分為三個(gè)階段:解析,轉(zhuǎn)換,生成。
babel 本身不具有任何轉(zhuǎn)化功能,它把轉(zhuǎn)化的功能都分解到一個(gè)個(gè) plugin 里面。因此當(dāng)我們不配置任何插件時(shí),經(jīng)過(guò) babel 的代碼和輸入是相同的。
插件總共分為兩種:
當(dāng)我們添加 語(yǔ)法插件 之后,在解析這一步就使得 babel 能夠解析更多的語(yǔ)法。(順帶一提,babel 內(nèi)部使用的解析類庫(kù)叫做 babylon,并非 babel 自行開發(fā))
舉個(gè)簡(jiǎn)單的例子,當(dāng)我們定義或者調(diào)用方法時(shí),最后一個(gè)參數(shù)之后是不允許增加逗號(hào)的,如 callFoo(param1, param2,) 就是非法的。如果源碼是這種寫法,經(jīng)過(guò) babel 之后就會(huì)提示語(yǔ)法錯(cuò)誤。
但最近的 JS 提案中已經(jīng)允許了這種新的寫法(讓代碼 diff 更加清晰)。為了避免 babel 報(bào)錯(cuò),就需要增加語(yǔ)法插件 babel-plugin-syntax-trailing-function-commas
當(dāng)我們添加 轉(zhuǎn)譯插件 之后,在轉(zhuǎn)換這一步把源碼轉(zhuǎn)換并輸出。這也是我們使用 babel 最本質(zhì)的需求。
比起語(yǔ)法插件,轉(zhuǎn)譯插件其實(shí)更好理解,比如箭頭函數(shù) (a) => a 就會(huì)轉(zhuǎn)化為 function (a) {return a}。完成這個(gè)工作的插件叫做 babel-plugin-transform-es2015-arrow-functions。
同一類語(yǔ)法可能同時(shí)存在語(yǔ)法插件版本和轉(zhuǎn)譯插件版本。如果我們使用了轉(zhuǎn)譯插件,就不用再使用語(yǔ)法插件了。
簡(jiǎn)單來(lái)講,使用babel就像如下流程:
源代碼 =babel=> 目標(biāo)代碼
如果沒(méi)有使用任何插件,源代碼和目標(biāo)代碼就沒(méi)有任何差異。當(dāng)我們引入各種插件的時(shí)候,就像如下流程一樣:
源代碼
|
進(jìn)入babel
|
babel插件1處理代碼:移除某些符號(hào)
|
babel插件2處理代碼:將形如() => {}的箭頭函數(shù),轉(zhuǎn)換成function xxx() {}
|
目標(biāo)代碼因?yàn)閎abel的插件處理的力度很細(xì),我們代碼的語(yǔ)法、語(yǔ)義內(nèi)容規(guī)范有很多,如果我們要處理這些語(yǔ)法,可能需要配置一大堆的插件,所以babel提出,將一堆插件組合成一個(gè)preset(預(yù)置插件包),這樣,我們只需要引入一個(gè)插件組合包,就能處理代碼的各種語(yǔ)法、語(yǔ)義。
所以,回到我們上述的那些@babel開頭的npm包,再回首可能不會(huì)那么迷茫:
@babel/core @babel/preset-env @babel/preset-typescript @babel/preset-react @babel/plugin-proposal-class-properties @babel/plugin-proposal-object-rest-spread
@babel/core毋庸置疑,babel的核心模塊,實(shí)現(xiàn)了上述的流程運(yùn)轉(zhuǎn)以及代碼語(yǔ)法、語(yǔ)義分析的功能。
以plugin開頭的就是插件,這里我們引入了兩個(gè):@babel/plugin-proposal-class-properties(允許類具有屬性)和@babel/plugin-proposal-object-rest-spread(對(duì)象展開)。
以preset開頭的就是預(yù)置組件包合集,其中@babel/preset-env表示使用了可以根據(jù)實(shí)際的瀏覽器運(yùn)行環(huán)境,會(huì)選擇相關(guān)的轉(zhuǎn)義插件包:
env 的核心目的是通過(guò)配置得知目標(biāo)環(huán)境的特點(diǎn),然后只做必要的轉(zhuǎn)換。
如果不寫任何配置項(xiàng),env 等價(jià)于 latest,也等價(jià)于 es2015 + es2016 + es2017 三個(gè)相加(不包含 stage-x 中的插件)。
{
"presets": [
["env", {
"targets": {
"browsers": ["last 2 versions", "safari >= 7"]
}
}]
]
}如上配置將考慮所有瀏覽器的最新2個(gè)版本(safari大于等于7.0的版本)的特性,將必要的代碼進(jìn)行轉(zhuǎn)換。而這些版本已有的功能就不進(jìn)行轉(zhuǎn)化了。
—— 摘自《一口(很長(zhǎng)的)氣了解 babel - 知乎 (zhihu.com)》
@babel/preset-typescript會(huì)處理所有ts的代碼的語(yǔ)法和語(yǔ)義規(guī)則,并轉(zhuǎn)換為js代碼;@babel/preset-react
故名思義,可以幫助處理使用React相關(guān)特性,例如JSX標(biāo)簽語(yǔ)法等。
webpack的基于babel-loader的處理流程
講了這么多,我們的打包工具webpack如何使用babel相關(guān)組件處理代碼的呢?還記得我們安裝過(guò)babel-loader嗎?
實(shí)際上,我們通過(guò)配置webpack.config.js,使用babel-loader建立起webpack處理代碼與babel處理代碼的連接:
diff --git a/webpack.config.js b/webpack.config.js
index 8bfbb63..6767fd8 100644
--- a/webpack.config.js
+++ b/webpack.config.js
@@ -17,6 +17,11 @@ module.exports = {
// 模塊
module: {
// 規(guī)則
- rules: []
+ rules: [
+ {
+ test: /\.tsx?$/,
+ use: 'babel-loader'
+ }
+ ]
}
};
(END)這一步的配置,就是讓webpack遇到ts或tsx的時(shí)候,將這些代碼交給babel-loader,babel-loader作為橋接把代碼交給內(nèi)部引用的@babel/core相關(guān)API進(jìn)行處理。
那么,@babel/core如何知道要使用我們安裝的各種plugin插件和preset預(yù)置插件包的呢?通過(guò).babelrc文件(注:實(shí)際上還有其他配置方式,但個(gè)人傾向于.babelrc)。這里,我們?cè)陧?xiàng)目根目錄創(chuàng)建.babelrc文件,并添加一下內(nèi)容:
{
"presets": [
"@babel/preset-env",
"@babel/preset-typescript",
"@babel/preset-react"
],
"plugins": [
"@babel/plugin-proposal-class-properties",
"@babel/plugin-proposal-object-rest-spread"
]
}這里的配置不難理解,plugins字段存放要使用的插件,presets字段存放預(yù)置插件包名稱,具體的配置可以查閱官方文檔。
總結(jié)一下,配置babel可以按照如下思路進(jìn)行:
- xxx.ts(x)代碼交給webpack打包;
- webpack遇到ts(x)結(jié)尾的代碼文件,根據(jù)webpack.config.js配置,交給babel-loader;
- babel-loader交給@babel/core;
- @babel/core根據(jù).babelrc配置交給相關(guān)的插件處理代碼,轉(zhuǎn)為js代碼;
- webpack進(jìn)行后續(xù)的打包操作。
引入React相關(guān)庫(kù)(externals方式)
還記得我們的需求嗎?
依賴的react、react-dom模塊以外部引用方式。
什么是外部引用方式?簡(jiǎn)單來(lái)講,我希望react、react-dom等組件庫(kù)的包,不會(huì)被打入到組件庫(kù)中,而是在html中引入(Add React to a Website – React (reactjs.org)):
<!-- ... other HTML ... --> <!-- Load React. --> <!-- Note: when deploying, replace "development.js" with "production.min.js". --> <script src="https://unpkg.com/react@17/umd/react.development.js" crossorigin></script> <script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js" crossorigin></script> <!-- 組件庫(kù)JS --> <script src="r-ui.js"></script> </body>
要實(shí)現(xiàn)這樣的效果,第一步是配置webapck.config.js:
diff --git a/webpack.config.js b/webpack.config.js
index 6767fd8..54fc0e5 100644
--- a/webpack.config.js
+++ b/webpack.config.js
@@ -13,7 +13,13 @@ module.exports = {
// webpack 默認(rèn)只處理js、jsx等js代碼
extensions: ['.js', '.jsx', '.ts', '.tsx']
},
- externals: {},
+ externals: {
+ // 打包過(guò)程遇到以下依賴導(dǎo)入,不會(huì)打包對(duì)應(yīng)庫(kù)代碼,而是調(diào)用window上的React和ReactDOM
+ // import React from 'react'
+ // import ReactDOM from 'react-dom'
+ 'react': 'React',
+ 'react-dom': 'ReactDOM'
+ },
// 模塊
module: {
// 規(guī)則
(END)第二部,在引入react相關(guān)庫(kù)的時(shí)候,可以不用引入到dependencies運(yùn)行時(shí)依賴,而只需要引入對(duì)應(yīng)的類型定義到devDependencies開發(fā)依賴中:
yarn add -D @types/react@17.0.39 @types/react-dom@17.0.17
diff --git a/package.json b/package.json
index 33c32b6..bd17763 100644
--- a/package.json
+++ b/package.json
@@ -15,6 +15,8 @@
"@babel/preset-env": "^7.18.2",
"@babel/preset-react": "^7.17.12",
"@babel/preset-typescript": "^7.17.12",
+ "@types/react": "17.0.39",
+ "@types/react-dom": "17.0.17",
"babel-loader": "^8.2.5",
"webpack": "^5.72.1",
"webpack-cli": "^4.9.2",至此,我們已經(jīng)完成了處理基于TypeScript的React項(xiàng)目的webpack配置,此時(shí)我們的項(xiàng)目結(jié)構(gòu)如下:
- r-ui |- .babelrc |- package.json |- webpack.config.js
階段演示1:基于TypeScript的React組件項(xiàng)目的webpack配置可行性
編寫組件代碼
新增src目錄,在src目錄下添加index.tsx(用于將所有的組件導(dǎo)出)
src目錄下添加components/button目錄,并創(chuàng)建index.tsx文件。具體結(jié)構(gòu)與目錄如下:
- r-ui |- src/components/button/index.tsx |- src/index.tsx |- ... ...
src/components/button/index.tsx
import * as React from 'react';
interface ButtonProps {
}
const Button: React.FC<ButtonProps> = (props) => {
const {children, ...rest} = props;
return <button {...rest} >{children}</button>
}
export default Button;src/index.tsx
export {default as Button} from './components/button';
修改package.json
添加webpack處理腳本
diff --git a/package.json b/package.json
index bd17763..01565ad 100644
--- a/package.json
+++ b/package.json
@@ -4,6 +4,7 @@
"description": "",
"main": "index.js",
"scripts": {
+ "build": "webpack --config webpack.config.js",
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
(END)編譯打包組件庫(kù)
yarn run build
打包完成后,在項(xiàng)目根目錄/dist目錄下,會(huì)生成一個(gè)r-ui.umd.js文件。
效果演示
想要查看效果,可以在dist目錄下添加如下的html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>r-ui example</title>
<script src="https://unpkg.com/react@17/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js"></script>
<!-- 注意r-ui.umd.js的路徑 -->
<script src="r-ui.umd.js"></script>
</head>
<body>
<div id="example"></div>
<script>
const onClick = () => {
alert('hello');
};
// window上存在rui,是因?yàn)槲覀儗⒔M件包導(dǎo)出為了umd包,取名為rui
// 使用React原生方法創(chuàng)建Button的react組件實(shí)例
// 等價(jià)于:
// <Button onClick={onClick}>hello, world</Button>
const button = React.createElement(rui.Button, {onClick}, 'hello, world');
// 調(diào)用ReactDOM方法,將button組件實(shí)例掛載到example DOM節(jié)點(diǎn)上
ReactDOM.render(button, document.getElementById('example'));
</script>
</body>
</html>- r-ui
|- dist
|- index.html
|- r-ui.umd.js
|- ... ...此時(shí),可以直接使用瀏覽器打開index.html查看效果:

處理樣式(less編譯與css導(dǎo)出)
依賴引入
根據(jù)上述內(nèi)容,我們已經(jīng)搭建了基礎(chǔ)的項(xiàng)目結(jié)構(gòu),但是目前來(lái)說(shuō)我們還需要處理我們的less樣式,并且能夠支持導(dǎo)出r-ui.umd.css樣式文件。基于此考慮,我們需要引入:
- less-loader。處理less樣式代碼,轉(zhuǎn)為css;
- less。由于less-loader內(nèi)部是調(diào)用了less模塊進(jìn)行l(wèi)ess代碼編譯,故還需要引入less(模式和babel-loader內(nèi)部使用@babel/core一樣);
- css-loader。處理css樣式代碼,進(jìn)行適當(dāng)加工;
- mini-css-extract-plugin。MiniCssExtractPlugin的loader用于進(jìn)一步處理css,并且該插件用于導(dǎo)出獨(dú)立樣式文件。
yarn add -D less-loader less css-loader mini-css-extract-plugin
diff --git a/package.json b/package.json
index 01565ad..3070d07 100644
--- a/package.json
+++ b/package.json
@@ -19,6 +19,10 @@
"@types/react": "17.0.39",
"@types/react-dom": "17.0.17",
"babel-loader": "^8.2.5",
+ "css-loader": "^6.7.1",
+ "less": "^4.1.2",
+ "less-loader": "^11.0.0",
+ "mini-css-extract-plugin": "^2.6.0",
"webpack": "^5.72.1",
"webpack-cli": "^4.9.2",
"webpack-dev-server": "^4.9.0"配置webpack
根據(jù)上述依賴,我們可以知道需要less-loader、css-loader以及MiniCssExtractPlugin的內(nèi)置loader來(lái)處理我們的樣式代碼。但是配置到webpack需要注意: webpack中的順序是【從后向前】鏈?zhǔn)秸{(diào)用的,所以注意下面配置的代碼中use數(shù)組的順序:
diff --git a/webpack.config.js b/webpack.config.js
index 54fc0e5..9db43b8 100644
--- a/webpack.config.js
+++ b/webpack.config.js
@@ -1,5 +1,6 @@
// webpack.config.js
const {resolve} = require("path");
+const MiniCssExtractPlugin = require('mini-css-extract-plugin');
module.exports = {
// 組件庫(kù)的起點(diǎn)入口
entry: './src/index.tsx',
@@ -27,7 +28,28 @@ module.exports = {
{
test: /\.tsx?$/,
use: 'babel-loader'
+ },
+ {
+ test: /\.less$/,
+ use: [
+ // webpack中的順序是【從后向前】鏈?zhǔn)秸{(diào)用的
+ // 所以對(duì)于less先交給less-loader處理,轉(zhuǎn)為css
+ // 再交給css-loader
+ // 最后導(dǎo)出css(MiniCssExtractPlugin.loader)
+ // 所以注意loader的配置順序
+ {
+ loader: MiniCssExtractPlugin.loader,
+ },
+ 'css-loader',
+ 'less-loader'
+ ]
}
]
- }
+ },
+ plugins: [
+ // 插件用于最終的導(dǎo)出獨(dú)立的css的工作
+ new MiniCssExtractPlugin({
+ filename: 'r-ui.umd.css'
+ }),
+ ]
};階段演示2:less樣式處理配置可行性
編寫樣式代碼
新增src/components/button/index.less
@color: #006fde;
.my-button {
color: @color;
}修改src/components/button/index.tsx
import * as React from 'react';
+// 引入less樣式
+import './index.less';
interface ButtonProps {
}
const Button: React.FC<ButtonProps> = (props) => {
const {children, ...rest} = props;
- return <button {...rest} >{children}</button>
+ // 使用my-button樣式
+ return <button {...rest} className='my-button'>{children}</button>
}
export default Button;編譯組件庫(kù)
再次打包組件庫(kù)以后,dist目錄下會(huì)額外生成文件:r-ui.umd.css。所以,我們需要在index.html中添加樣式文件的引入:
<head>
<meta charset="UTF-8">
<title>r-ui example</title>
<script src="https://unpkg.com/react@17/umd/react.development.js"></script>
<script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js"></script>
<script src="r-ui.umd.js"></script>
+ <link href="r-ui.umd.css" rel="external nofollow" rel="stylesheet"/>
</head>效果演示
刷新頁(yè)面后,可以看到按鈕的文字顏色已經(jīng)生效

引入AntDesign
根據(jù)我們的需求,我們希望將antd組件代碼引用到我們組件內(nèi)部進(jìn)行封裝,所以需要以dependencies方式引入:
yarn add antd
diff --git a/package.json b/package.json
index 3070d07..09ca792 100644
--- a/package.json
+++ b/package.json
@@ -26,5 +26,8 @@
"webpack": "^5.72.1",
"webpack-cli": "^4.9.2",
"webpack-dev-server": "^4.9.0"
+ },
+ "dependencies": {
+ "antd": "^4.20.6"
}
}引用antd的button樣式
src/components/button/index.less
-@color: #006fde;
-
-.my-button {
- color: @color;
-}
+@import "~antd/lib/button/style/index.css";引用antd的button組件
import * as React from 'react';
+// 使用antd的Button和ButtonProps
+// 為了不和我們的Button沖突,需要改導(dǎo)出名
+import {Button as AntdButton, ButtonProps as AntdButtonProps} from 'antd';
// 引入less樣式
import './index.less';
-interface ButtonProps {
+interface ButtonProps extends AntdButtonProps {
}
const Button: React.FC<ButtonProps> = (props) => {
const {children, ...rest} = props;
- // 使用my-button樣式
- return <button {...rest} className='my-button'>{children}</button>
+ // 使用AntdButton
+ return <AntdButton {...rest}>{children}</AntdButton>
}
export default Button;階段演示3:antd組件引入可行性
通過(guò)上述的代碼修改以后,我們直接進(jìn)行編譯,然后檢查效果即可:

寫在最后
實(shí)際上,代碼開發(fā)過(guò)程中,還有很多可以輔助開發(fā)的模塊、流程,例如eslint檢查,熱更新等。但是那些內(nèi)容不在本文的討論范圍。后續(xù)會(huì)出相關(guān)的文章再進(jìn)一步進(jìn)行介紹。
本文所搭建的整個(gè)項(xiàng)目,我都按照文章一步一步進(jìn)行了git提交,開發(fā)小伙伴可以邊閱讀文章邊對(duì)照git提交一步一步來(lái)看。
github地址:w4ngzhen/r-ui (github.com)
到此這篇關(guān)于從零搭建react+ts組件庫(kù)(封裝antd)的文章就介紹到這了,更多相關(guān)react+ts組件庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳細(xì)談?wù)凴eact中setState是一個(gè)宏任務(wù)還是微任務(wù)
學(xué)過(guò)react的人都知道,setState在react里是一個(gè)很重要的方法,使用它可以更新我們數(shù)據(jù)的狀態(tài),下面這篇文章主要給大家介紹了關(guān)于React中setState是一個(gè)宏任務(wù)還是微任務(wù)的相關(guān)資料,需要的朋友可以參考下2021-09-09
優(yōu)雅的在React項(xiàng)目中使用Redux的方法
這篇文章主要介紹了優(yōu)雅的在React項(xiàng)目中使用Redux的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
修復(fù)Next.js中window?is?not?defined方法詳解
這篇文章主要為大家介紹了修復(fù)Next.js中window?is?not?defined方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
webpack手動(dòng)配置React開發(fā)環(huán)境的步驟
本篇文章主要介紹了webpack手動(dòng)配置React開發(fā)環(huán)境的步驟,webpack手動(dòng)配置一個(gè)獨(dú)立的React開發(fā)環(huán)境, 開發(fā)環(huán)境完成后, 支持自動(dòng)構(gòu)建, 自動(dòng)刷新, sass語(yǔ)法 等功能...感興趣的小伙伴們可以參考一下2018-07-07
React?Native?加載H5頁(yè)面的實(shí)現(xiàn)方法
這篇文章主要介紹了React?Native?加載H5頁(yè)面的實(shí)現(xiàn)方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04
react native 原生模塊橋接的簡(jiǎn)單說(shuō)明小結(jié)
這篇文章主要介紹了react native 原生模塊橋接的簡(jiǎn)單說(shuō)明小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02

