自动化把 简单的svg icons(具体要求见下面的压缩规则)批量构建为react组件,并对svg进行内容压缩
const getCode = require('build-react-svg');
genCode(originDir, compsDir, demoFilePath, { defaultClass: 'lls-cc-svg-icon' });
- originsDir: 原始svg所在文件夹,里面的svg文件只能有一层, 不能存在
originsDir/xx/yy.svg
, 只能是originsDir/yy.svg
- compsDir: 组件文件目录, react组件将会自己写入这个文件夹
- demoFilePath: 会生成一个 DemoComp, 包含所有的svg icons(样式可能需要自己写)
- options:
defaultClass
, 默认是lls-svg-icon
. 每个react svg 组件会加 className, 命名规则是 defaultClass + ' ' + 和fileName 的classNamecompTplStr
, 生成 react component 的njk模板,默认为src/react.njk. 你可以根据需要进行微调。demoTplStr
, 生成 demo component 的njk模板。 用来展示所有生成的svg组件的,默认为src/demo.njk. 你可以根据需要进行微调。svgo
, svgo 实例,用来进行svg内容的压缩,具体参考svgo
项目force
, 如果react component 已经存在,默认不覆盖,force 设为true, 强制覆盖
见 代码