对于大中型前端项目为了解耦与复用,更多的公司会选择本身封装组件库,那么一次引入整个组件库必然致使项目过大,如何按需加载则必需要作javascript
[git项目地址](https://github.com/ant-design/babel-plugin-import)
在babel转码的时候,把整个库‘antd’的引用,变为'antd/lib/button'具体模块的引用。这样webpack收集依赖module就不是整个antd,而是里面的button.import { Button } from 'antd';
ReactDOM.render(<Button>xxxx</Button>);
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/button');
ReactDOM.render(<_button>xxxx</_button>);
复制代码
那么天然咱们的组件也能够一样的处理,以anole-lego为例 前端
babel-loader
// 编译添加
include: [
path.resolve(appDirectory, 'node_modules/anole-lego'),
//...others
]
// 按需加载支持
// npm/yarn 安装依赖 `babel-plugin-import` 详细参见该插件使用
// 配置以下
plugins: [
['import', {
'libraryName': 'anole-lego',
// libraryDirectory: 'lib',
camel2DashComponentName: false, // 是否须要驼峰转短线
camel2UnderlineComponentName: false, // 是否须要驼峰转下划线
customName: (name) => {
return `anole-lego/lib/components/${name}` // 核心配置 根据你本身的组件目录配置
},
style: () => {
return false
}
}],
//...others
]
复制代码
import { Button } from 'anole-lego';
ReactDOM.render(<Button>Start</Button>, mountNode);
复制代码