babel的命令行工具babel-cli解析

babel内置一个cli,可通过命令行操作编译文件

首先要安装: npm i --save-dev babel-cli 

babel-cli分为两部分:babel 和 babel-node

babel命令只会编译文件代码而不会执行代码

执行需要编译的文件:

文件script.js:
let fn = () => {console.log('babel cli')};
fn();

命令行执行:
npx babel script.js
# 输出 var fn = function fn(){console.log('babel cli')}; fn();

输出编译结果到单个文件:

npx babel script.js --out-file script-compiled.js

监测文件的修改同时编译:

npx babel script.js --watch --out-file script-compiled.js

编译整个src文件夹目录并将其输出到lib目录:

npx babel src --out-dir lib

编译整个src文件夹目录并将其输出到单个文件:

npx babel src --out-file script-complied.js

编译src目录的时候忽略test和spec文件:

npx babel src --out-dir lid --ignore test.js,spec.js

编译的时候使用plugins和presets:

npx babel script.js --plugins=transform-runtime
npx babel script.js --presets=es2015,stage-2

忽略 .babelrc 的配置:

npx babel --no-babelrc script.js

babel-cli提供另一个cli即babel-node,可以直接在命令行执行代码,babel-node与node cli的功能相同,只是会在node执行文件之前先编译es6等代码。

编译并运行script.js:

文件script.js:
let fn = () => {console.log('babel-node')};
fn();

命令行执行:
npx babel-node script.js
# 输出 babel-node

不建议在生产环境中使用babel-node,因为编译中的缓存数据存储在内存中,造成不必要的内存占用。而整个应用程序需要及时编译,会一直面临应用启动的性能问题。

 

posted @ 2018-01-11 12:25  赵大树  阅读(1876)  评论(0编辑  收藏  举报