关于js的编译和压缩,之前做过一个小工具了,主要就是自己项目成员大都没有这部分的技能,导致发布的时候总需要去编译压缩下.. 最终做了个命令行小工具.. 问题不在这里,前一阵子做压缩的时候发现压缩后竟然是undefined.最终才发现是es6的语法问题。
undefined
在对某个项目内的js
文件做压缩的时候,发现了这个问题。结果发现是uglify-js
不支持es6
的语法和api
。
最终只能通过babel
来进行编译。
对之前封装的命令行工具compressj2
做了改版。
let babel = require('@babel/core');
let baseCode = `let {a} = {a :'name'}`;
babel.transform(baseCode, {
presets: [
['@babel/preset-env', {
"useBuiltIns": "entry",
"modules": false,
"corejs": 2, // 新版本的@babel/polyfill包含了core-js@2和core-js@3版本,所以需要声明版本,否则webpack运行时会报warning,此处暂时使用core-js@2版本(末尾会附上@core-js@3怎么用)
}]
]
}, function(erra, result) {
if (erra) {
console.log('>>:' + filePath);
console.log(erra);
} else {
console.log(result.code);
}
});
babel
的版本是7
以上,与之前的老版本会有差异。这个一定要注意。
关于babel
的使用,参考https://segmentfault.com/a/1190000019718925
npm install compressjs2 -g
compress //压缩当前目录下所有js并替换
compress -d /home/js //压缩目标目录下js并替换
compress -d /home/js -o /home/build //压缩目标目录下js并输出到/home/build目录下
compress -c //美化压缩后的js文件
compress -l //递归循环调用所有目录,否则只有当前级别
//本工具中对js的编译的以上代码,很多`api`并没有增加,主要是对语法进行编译。
对babel的使用很粗浅,不过目前可以满足现有的环境要求。
以后项目再发布做编译压缩的时候.. 只需要一个简单的命令compress
就OK啦。
转载请注明出处: https://chrunlee.cn/article/js-babel-uglify-tool.html