babel-plugin-import
在 Babel 配置中引入该插件,可以针对 antd, antd-mobile, lodash, material-ui等库进行按需加载.
为什么需要 babel-plugin-import
如何在项目中添加 babel-plugin-import
例子
{ "libraryName": "antd" }
import { Button } from 'antd';
ReactDOM.render(<Button>xxxx</Button>);
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/button');
ReactDOM.render(<_button>xxxx</_button>);
{ "libraryName": "antd", style: "css" }
import { Button } from 'antd';
ReactDOM.render(<Button>xxxx</Button>);
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/button');
require('antd/lib/button/style/css');
ReactDOM.render(<_button>xxxx</_button>);
{ "libraryName": "antd", style: true }
import { Button } from 'antd';
ReactDOM.render(<Button>xxxx</Button>);
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/button');
require('antd/lib/button/style');
ReactDOM.render(<_button>xxxx</_button>);
备注 : 配置 style: true
则在项目编译阶段,可以对引入的 antd 样式文件进行编译,从而可以压缩打包尺寸;而配置style: "css"
, 则直接引入经过打包后的 antd 样式文件
使用方式
npm install babel-plugin-import --save-dev
通过 .babelrc
配置文件或者 babel-loader 模块编程引入.
{
"plugins": [["import", options]]
}
options
options
can be object.
{
"libraryName": "antd",
"style": true, // or 'css'
}
{
"libraryName": "lodash",
"libraryDirectory": "", //表示从库的package.json的main入口;否则默认为lib文件夹
"camel2DashComponentName": false, // default: true,将引入的组件名转化为"-"连接的文件名
}
{
"libraryName": "@material-ui/core",
"libraryDirectory": "components", // default: lib
"camel2DashComponentName": false, // default: true
}
It's not available in babel@7+options
can be an array.
For Example:
[
{
libraryName: 'antd',
libraryDirectory: 'lib', // default: lib
style: true
},
{
libraryName: 'antd-mobile'
}
];
Options
can't be an array in babel@7+, but you can add plugins with name to support multiple dependencies.
For Example:
// .babelrc
"plugins": [
["import", { "libraryName": "antd", "libraryDirectory": "lib"}, "ant"],
["import", { "libraryName": "antd-mobile", "libraryDirectory": "lib"}, "antd-mobile"]
]
style
-
["import", { "libraryName": "antd" }]
: import js modularly -
["import", { "libraryName": "antd", "style": true }]
: import js and css modularly (LESS/Sass source files) -
["import", { "libraryName": "antd", "style": "css" }]
: import js and css modularly (css built files)
If option style is a Function
, babel-plugin-import
will auto import the file which filepath equal to the function return value. This is useful for the components library developers.
e.g.
-
["import", { "libraryName": "antd", "style": (name) =>
${name}/style/2x}]
: import js and css modularly & css file path isComponentName/style/2x
If a component has no style, you can use the style
function to return a false
and the style will be ignored.
e.g.
[
'import',
{
libraryName: 'antd',
style: (name: string, file: Object) => {
if (name === 'antd/lib/utils') {
return false;
}
return `${name}/style/2x`;
}
}
];
customName
使用 customName
来自定义导入文件路径.
插件默认导入文件的基础路径为 lib 目录,并且默认将引入的组件名转换为按照"-"连接的结构:
import { TimePicker } from "antd"
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/time-picker');
设置 camel2DashComponentName
为 false
来阻止组件名称的转换:
import { TimePicker } from "antd"
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/TimePicker');
在 Babel 配置文件中,使用 customName
来自定义导入组件路径:
[
'import',
{
libraryName: 'antd',
customName: (name: string) => {
if (name === 'TimePicker') {
return 'antd/lib/custom-time-picker';
}
return `antd/lib/${name}`;
}
}
];
上面编译后的结果为:
import { TimePicker } from "antd"
↓ ↓ ↓ ↓ ↓ ↓
var _button = require('antd/lib/custom-time-picker');
transformToDefaultImport
如果打包后的模块没有default
导出,则设置 false
备注
babel-plugin-import will not work properly if you add the library to the webpack config vendor.
https://swift.ctolib.com/article/wiki/108814
babel-plugin-import-custom
针对iview做了额外的优化,https://github.com/videring/babel-plugin-import-custom/blob/master/README.md
网友评论