Rollup:打包 TypeScript - React 组件库

调用浏览器摄像头拍照组件

  • 1、前提
  • 1、安装依赖
  • [2、添加 rollup.config.js 配置](#2、添加 rollup.config.js 配置)
  • [3、修改 package.json](#3、修改 package.json)
    • [3.1 添加打包命令](#3.1 添加打包命令)
    • [3.2 添加组件入口](#3.2 添加组件入口)
    • [3.3 添加组件声明入口](#3.3 添加组件声明入口)
    • [3.4 浏览器支持](#3.4 浏览器支持)

1、前提

1.1 通过 create-react-app take-photo --template 创建前端应用

1.2 添加组件 TakePhoto (拍照组件)

1.3 App 为测试组件

1.4 目录结构

1、安装依赖

powershell 复制代码
@rollup/plugin-commonjs 
@rollup/plugin-image
@rollup/plugin-node-resolve
@rollup/plugin-terser
@rollup/plugin-typescript
autoprefixer
postcss
postcss-preset-env
postcss-url
rollup
rollup-plugin-delete
rollup-plugin-postcss

2、添加 rollup.config.js 配置

javascript 复制代码
const { nodeResolve } = require('@rollup/plugin-node-resolve');
// 允许使用 node 或 umd 包
const commonjs = require( '@rollup/plugin-commonjs');
// 打包前清空输出目录
const del = require( 'rollup-plugin-delete');
// 压缩代码
const terser = require('@rollup/plugin-terser');
// 编译 TS 代码
const typescript = require( '@rollup/plugin-typescript');
// 处理scss
const postcss = require( 'rollup-plugin-postcss');
// 处理scss 添加前缀
const autoprefixer = require( 'autoprefixer');
// 处理 css 中引入的图片
const postCssUrl = require("postcss-url");
// 处理组件引入的图片
const image = require('@rollup/plugin-image');

module.exports = {
  input: 'src/TakePhoto/index.tsx',
  output: [
    {
      file: 'dist/TakePhoto/index.js',
      format: 'umd',
      name: 'TakePhoto',
      globals: {
        react: 'React',
        'react-dom': 'ReactDom'
      }
    }
  ],
  external: ['react', 'react-dom'],
  plugins: [
    del({ targets: 'dist/*', verbose: true }),
    nodeResolve(),
    commonjs(),
    terser(),
    typescript({
      "include": [
        "src/TakePhoto/*",
        "src/types.d.ts"
      ]
    }),
    postcss({
      extensions: ['.css', '.scss'],
      inject: true,
      minimize: true,
      plugins: [
        postCssUrl({
          url: 'inline'
        }),
        autoprefixer()
      ],
    }),
    image()
  ]
};

3、修改 package.json

3.1 添加打包命令

javascript 复制代码
"scripts": {
    // 其他命令...
    "build": "rollup --config"
},

3.2 添加组件入口

javascript 复制代码
"main": "dist/TakePhoto/index.js",

3.3 添加组件声明入口

javascript 复制代码
"types": "dist/TakePhoto/index.d.ts",

3.4 浏览器支持

javascript 复制代码
"browserslist": [
    ">0.2%",
    "not dead",
    "not op_mini all",
    "Firefox >= 52",
    "IE >= 10"
],
相关推荐
U.2 SSD4 分钟前
ECharts漏斗图示例
前端·javascript·echarts
江城开朗的豌豆4 分钟前
我的小程序登录优化记:从短信验证到“一键获取”手机号
前端·javascript·微信小程序
excel7 分钟前
Vue Mixin 全解析:概念、使用与源码
前端·javascript·vue.js
IT_陈寒14 分钟前
Java性能优化:这5个Spring Boot隐藏技巧让你的应用提速40%
前端·人工智能·后端
勇往直前plus32 分钟前
CentOS 7 环境下 RabbitMQ 的部署与 Web 管理界面基本使用指南
前端·docker·centos·rabbitmq
Never_Satisfied34 分钟前
在JavaScript / HTML中,Chrome报错此服务器无法证实它就是xxxxx - 它的安全证书没有指定主题备用名称
javascript·chrome·html
艾小码38 分钟前
零基础学JavaScript:手把手带你搭建环境,写出第一个程序!
javascript
北海-cherish6 小时前
vue中的 watchEffect、watchAsyncEffect、watchPostEffect的区别
前端·javascript·vue.js
AALoveTouch7 小时前
网球馆自动预约系统的反调试
javascript·网络
2501_915909067 小时前
HTML5 与 HTTPS,页面能力、必要性、常见问题与实战排查
前端·ios·小程序·https·uni-app·iphone·html5