源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

babel基本使用详解

  • 时间:2020-05-30 11:58 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:babel基本使用详解
[b]什么是babel?[/b] babel是一个强大的多用途js编译器 点击进入[url=http://babeljs.io/]官网[/url] [b]安装babel[/b]
npm install -g babel-cli 
npm install --save-dev babel-cli
[b]babel配置文件[/b] 通过.babelrc来表示
{
 "presets" : [ ],
 "plugins" : [ ]
}
presets用来存放一些预设 plugins用来存放一些插件  [b]命令行的简单使用[/b] 我们可以通过 -o (--out-file) 参数来编译一个文件 [code]babel es6.js -o es5.js / babel es6 --out-file es5.js[/code] 如果我们想编译整个目录 -d (--out-dir)参数 [code]babel  src -d build / babel  src --out-dir build[/code] [b]预设[/b] 现在有一段es6的代码,我们想要使用babel来编译这段代码, 目前来说通过编译后的代码几乎是原封不动的复制了过来 es6.js
var add = (a,b) =>{
 console.log(a+b)
}
add(1,2)
我们可以安装babel-preset-es2015来解析es2015的语法 [code]npm install --save-dev babel-preset-es2015[/code] 然后通过配置.babelrc文件
{
 "presets": ["es2015"]
}
这样我们就可以进行对es2015语法解析了。最后通过配置package.json的scripts
"scripts": {
 "build" : "babel src -d build -w"
 }
接下来直接在命令行 [code]npm run build[/code] [b]插件[/b] 在babel中有很多很多的插件, 例如我们要将下面一段代码转换成umd的形式,该如何做呢?
var add = (a,b) =>{
 console.log(a+b)
}
add(1,2)
首先找到对应的插件babel-plugin-transform-es2015-modules-umd,安装该插件 [code]npm install --save-dev babel-plugin-transform-es2015-modules-umd[/code] 在配置中引入
{
 "presets":["es2015"],
 "plugins":["transform-es2015-modules-umd"]
}
然后编译后就是我们想要的了
(function (global, factory) {
 if (typeof define === "function" && define.amd) {
 define(["module", "exports"], factory);
 } else if (typeof exports !== "undefined") {
 factory(module, exports);
 } else {
 var mod = {
  exports: {}
 };
 factory(mod, mod.exports);
 global.sum = mod.exports;
 }
})(this, function (module, exports) {
 "use strict";
 Object.defineProperty(exports, "__esModule", {
 value: true
 });
 var sum = function sum(a, b) {
 return a + b;
 };
 exports.default = sum;
 module.exports = exports["default"];
});
[b]集成gulp[/b] babel可以单独使用, 也可以配合构建工具(gulp webpack等)进行结合 首先要下载gulp 和gulp对应的babel插件 [code]npm install gulp gulp-babel --save-dev[/code] 创建gulp配置gulpfile.js
const gulp = require('gulp')
const babel = require('gulp-babel')
gulp.task('babel', ()=>{
 return gulp.src('src/**/*.js')
  .pipe(babel())  
  .pipe(gulp.dest('dist'))
})
gulp.task('default' , ['babel'])
配置下package.json中的scripts
"scripts": {
 "dev" : "./node_modules/.bin/gulp"
 }
最后执行命令 [code]npm run dev[/code] 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程素材网!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部