如何从0到1搭建基于antd的monorepo库——子包初始化(二)
文章系列
上一章:# 如何从0到1搭建基于antd的monorepo库——初始化(一)
作者有话说
目前已经实现了一部分功能,源代码在 github,欢迎大家 Star 和 PR,一些待实现的功能都在 issue 中,感兴趣的同学可以一起加入进来。
看完这个系列可以收获什么:
- 如何使用 pnpm workspace + lerna 搭建 monorepo 仓库
- antd 的单个组件怎么进行文件结构的设计
- 基于 antd form 实现一个 Json 渲染表单
- antd 的打包方式以及如何使用 rollup 实现
- 如何发布 monorepo 包到 npm
前瞻
组件库技术选型:
- pnpm 10
- node 20
- lerna 8
- react 18
- antd 5
- dumi 2
正片开始
basic 包初始化
修改 package.json
文件。
{
"dependencies": {
"@ant-design/icons": "^6.0.0"
},
"devDependencies": {
"typescript": "^5.8.2"
},
"peerDependencies": {
"antd": "catalog:",
"react": "catalog:",
"react-dom": "catalog:"
},
}
运行 pnpm i
安装依赖。
在根目录下新增 tsconfig.json
文件。
{
"compilerOptions": {
"target": "ES5",
"module": "ESNext",
"moduleResolution": "node",
"baseUrl": ".",
"paths": {
"@kc-components/*": ["packages/*/src"]
},
"jsx": "react-jsx",
"jsxImportSource": "react",
"skipLibCheck": true,
"types": ["react", "react-dom"],
"strict": true,
"noImplicitAny": false,
"forceConsistentCasingInFileNames": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"sourceMap": true,
"inlineSources": true,
"importHelpers": false
},
"include": ["src/**/*"],
"exclude": ["node_modules", "dist", "es", "lib"]
}
在根目录下新增 src
文件夹,以及 src/index.ts
文件。
utils 包初始化
修改 package.json
文件。
{
"devDependencies": {
"typescript": "^5.8.2"
},
}
执行 pnpm i
安装依赖。
新增 tsconfig.json
文件。
{
"compilerOptions": {
"target": "ES5",
"module": "ESNext",
"moduleResolution": "node",
"baseUrl": ".",
"paths": {
"@kc-components/*": ["packages/*/src"]
},
"jsx": "react-jsx",
"jsxImportSource": "react",
"skipLibCheck": true,
"types": ["react", "react-dom"],
"strict": true,
"noImplicitAny": false,
"forceConsistentCasingInFileNames": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"sourceMap": true,
"inlineSources": true,
"importHelpers": false
},
"include": ["src/**/*"],
"exclude": ["node_modules", "dist", "es", "lib"]
}、
新增 src
文件夹,以及 src/index.ts
文件。
总结
至此,整个组件库的架子已经搭好,接下来,我们将会基于 antd form 实现一个 Json 渲染表单组件。
如果想提前知道更多内容可以直接查看github,欢迎大家 Star 和 PR,如有疑问可以评论或私信。