background

The company’s front-end component library was developed by several front-end leaders based on the React and Ant Design secondary extension library. The previous idea was that each business module maintained its own business component library based on the common component library. After several cycles, it was found that it was out of control, and the Ant Design version of each business module was different. In order to tighten the gap and maintain the expansion later, we decided to package the public library and publish it to NPM private server, and then install it to their respective business lines to ensure the consistency of the business lines. This is the background

packaging

Before this, I had experience in rollup packaging, and I also planned to use rollup to implement it here. During this process, I encountered many problems. After checking relevant materials, I found that there were few packages based on Rollup React in China, so BASED on this experience, I would like to sort them out for subsequent reference.

  • The rollup-plugin-commonjs plugin was introduced because the project exported the index.js file in the folder by default
  • React component “<” parse error, introduce @babel/preset- React
  • Rollup.config.js plugins are not in the correct order, Babel () is followed by commjs(), otherwise commjs() is wrapped in error number 2
  • Error: @babel/plugin-proposal-class-properties
  • @babel/plugin-proposal-decorators. Babelrc must precede class-properties
  • Used in the codeNew featuresError reported, introduce @babel/preset-env
  • Use rollup-plugin-less/rollup-plugin-less-modules to package the CSS file. Replace it with rollup-plugin-postcss/rollup-plugin-less

Start the

  • Error: babel@babel /plugin-transform-runtime
  • Error: async/await error: async/await error: async/await error

@babel/ plugin-transform-Runtime: “7.1.0”/”@babel/runtime”: “7.1.2” The last three problems are caused by ESLINT checking and resolved by shutting down ESLINT

  • Before, there were mutual references between the whole library, resulting in the generated index.js after packaging, there are references under the import library and references to the absolute path, resulting in an error when the runtime cannot find the referenced file. Rollup thinks that ysS-biz is a dependency, but the runtime does not actually exist. Finally, rollup-plugin-includePaths is introduced to convert the yss-biz alias into relative paths
  • Uglif plugin compression error, replace with rollup-plugin-terser

Finally packaged successfully

  • Unused external imports cannot be imported because uglify is imported but it does not work.ignore
  • Circular dependencies: < span style = “box-style: border-box; display: block; display: block;ignore
  • this has been rewritten to undefinedThis is because the code in the library used the arrow function incorrectly and then bound itthis.ignore
  • Unused External imports This is because the imported content is not used.ignore

configuration

rollup.config.js

import commonjs from "rollup-plugin-commonjs";
import babel from "rollup-plugin-babel";
import postcss from "rollup-plugin-postcss";
import ascii from "rollup-plugin-ascii";
import resolve from "@rollup/plugin-node-resolve";
import includePaths from "rollup-plugin-includepaths";
import { terser } from "rollup-plugin-terser";

const externalAry = [
  "antd"."antd/es/locale/zh_CN"."antd/dist/antd.css"."moment"."moment/locale/zh-cn"."echarts"."prop-types"."snowflake-id"."win-trade-base"."@lugia/lugiax"."@ant-design/icons"."react"."react-transition-group"."react-dnd"."react-dnd-html5-backend"."react-loadable"."react-resizable",];export default {
  input: "yss-biz-base/index.js",
  output: {
    file: "dist/index.js",
    format: "esm",
    sourcemap: true,
  },
  plugins: [
    resolve(),
    includePaths({
      include: { "yss-biz": "./yss-biz-base/index.js" },
    }),
    babel({ exclude: "**/node_modules/**", runtimeHelpers: true }),
    commonjs(),
    ascii(),
    postcss({
      // Extract CSS to the same location where JS file is generated but with .css extension.
      extract: true,
      // Use named exports alongside default export.
      namedExports: true,
      // Minimize CSS, boolean or options for cssnano.
      minimize: true,
      // Enable sourceMap.
      sourceMap: true. // This plugin will process files ending with these extensions and the extensions supported by custom loaders. extensions: [".less".".css"],}), terser(),], // Regular matching cannot be used, there are custom components named external: externalAry,};Copy the code

package.json

  "dependencies": {
    "@babel/core": "^ 7.10.0"."@babel/plugin-proposal-class-properties": "^ 7.8.3"."@babel/plugin-proposal-decorators": "^ 7.10.0"."@babel/plugin-syntax-jsx": "^ 7.8.3"."@babel/plugin-transform-react-jsx": "^ 7.9.4"."@babel/plugin-transform-runtime": "7.1.0"."@babel/preset-env": "^ 7.10.0"."@babel/preset-react": "^ 7.10.0"."@babel/runtime": "7.1.2."."@rollup/plugin-node-resolve": "^ 8.0.0." "."rollup": "^ 2.10.9"."rollup-plugin-ascii": "^ 0.0.3"."rollup-plugin-babel": "^ 4.4.0"."rollup-plugin-commonjs": "^ 10.1.0"."rollup-plugin-includepaths": "^ 0.2.3"."rollup-plugin-less": "^ 1.1.2." "."rollup-plugin-postcss": "^ 3.1.1." "."rollup-plugin-terser": "^ 6.1.0"
  },
  "devDependencies": {
    "colors": "^ 1.4.0." "."inquirer": "^ 7.1.0"
  }
Copy the code

.babelrc

{
  "presets": ["@babel/preset-env"."@babel/preset-react"]."plugins": [
    "@babel/plugin-syntax-jsx"["@babel/plugin-proposal-decorators", { "legacy": true}]."@babel/plugin-proposal-class-properties"."@babel/plugin-transform-react-jsx"."@babel/plugin-transform-runtime"]}Copy the code

release

Release to NPM private server part of the website data more, according to the steps to the basic there is no problem

data

www.bilibili.com/video/av893…

Github.com/rollup/roll…

The first record to write an article, writing limited, many inclusive, ヾ(´ 漢 ‘) Blue Thank you