npm run build 打包 之后怎么用_基于createreactapp打包编译自己的第三方UI组件库

本文介绍了如何使用create-react-app初始化项目,配置package.json,并详细讲解了打包及发布自定义UI组件库的过程。
摘要由CSDN通过智能技术生成

这篇文章主要是总结一下我们在工作中如何为公司开发内部的第三方UI组件,并通过npm install的方式安装的一些步骤和思路。 在学习完这套发布方法后大家也可以快速的发布自己的UI库到npm,供他人使用,就比如elementUI或者Ant Design。

实现效果

首先我们看一下实现效果,比如我们本地开发了一个Tag组件: f576938692f5d503ae9f7b52c2524f27.png 蓝色的按钮就是我们的tag组件,接下来我们把它发布到npm上,效果如下: 3874d182a4a9c153fe9d335a8815dbce.png 此时我们就可以用npm install的方式安装我们的组件并使用了。

实现

首先我是基于create-react-app来打包我们的UI库的,因为比较方便简单,当然我们也可以使用自己搭建的webpack来实现这一过程。
1.通过create-react-app快速启动一个项目:
npx create-react-app alex_xucd alex_xunpm start
2.设计组件库目录结构 我们在create-react-app创建的项目下的src目录下新建components用来存放我们的组件,用app.js要导入我们的组件来测试效果,我们会把打包后的组件目录放在lib下,目录大致如下: d9d39a4da4cfabb1965d2699a25a7b05.png
3.配置package.json文件
package.json主要用来设置组件库的信息及打包脚本,就好比我们用vue/react脚手架搭建项目一样,大家应该都很熟悉了:
{  "name": "@alex_xu/ui",  "version": "0.0.1",  "description": "A Design UI library for React",  "main": "lib/index.js",  "module": "es/index.js",  "author": "alex_xu",  "private": false,  "license": "MIT",  "publishConfig": {    "registry": "你的npm仓库地址"  },  "repository": {    "type": "git",    "url": "git+你的git仓库地址"  },  "bugs": {    "url": "issues地址"  },  "files": [    "es",    "lib"  ],  "homepage": "组件库的主页",  "keywords": [    "react",    "components",    "ui",    "framework",    "frontend"  ],  "peerDependencies": {    "react": ">=16.5.0",    "react-dom": ">=16.5.0"  },  "scripts": {    "start": "node scripts/start.js",    "build": "node scripts/build.js",  },  "eslintConfig": {    "extends": "react-app"  },  "browserslist": {    "production": [      ">0.2%",      "not dead",      "not op_mini all"    ],    "development": [      "last 1 chrome version",      "last 1 firefox version",      "last 1 safari version"    ]  },  "devDependencies": {    "@babel/cli": "^7.6.4",    "@babel/core": "^7.6.4",    "@babel/plugin-syntax-dynamic-import": "^7.2.0",    "@babel/preset-env": "^7.6.3",    "@babel/preset-react": "^7.6.3",    "babel-plugin-import": "^1.12.2"  },  // ...}
这里的script配置只是运行时配置,打包的时候我们会写单独的配置脚本去执行打包,然后打包jsx语法我们需要手动配置babel,所以我们会安装babel插件,babel配置如下:
const presets = [    [        "@babel/preset-env",   // 将ES6语法转换为es5        {            "useBuiltIns": "usage",    // 只编译需要编译的代码            "corejs": "3.0.1",        }    ],      "@babel/preset-react"];const plugins = [    "@babel/plugin-syntax-dynamic-import",    ["import", { "libraryName": "antd", "style": true }]]module.exports = { presets, plugins }
接下来安装babel模块:
npm i @babel/cli @babel/core @babel/preset-env @babel/preset-react -D
这里为了设置兼容多平台的环境变量,我们还需要用到cross-env, 拷贝css需要cpx,
npm i cross-env cpx -D
需要安装的插件已经完成,现在可以写打包组件的shell脚本了(建议在在根目录下创建):
cross-env BABEL_OUTPUT=commonjs babel src/components --out-dir lib/babel src/components --out-dir es/# 拷贝csscpx \"src/components/**/*.css\" es"cpx \"src/components/**/*.css\" lib"
接下来我们继续我们的组件库发布。
4.发布组件库
首先假定我们在components下写好了第一个组件Tag,我们在components的index.js统一导出:
export { default as Tag } from './Tag';// ...
然后执行我们的shell脚本:
bash build.sh
执行完可以发现在根目录下多了lib和es的目录,里面即使我们打包后的组件,一种遵循es规范,一种遵循cjs规范。

发布

npm publish --access public
--access是设置npm的访问级别,有public|restricted, restricted是限制访问,如果要发开源包,一般设置为public。 5f454e3c3030aa64dd07b6e044ee3756.png 往期回顾: 1、css大法之使用伪元素—实现超实用的图标库 2、前端工程师凭什么这么值钱? 3、使用纯css实现网站换肤和焦点图切换动画

080bb1610e269e8f2a3a749d17625078.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值