babel

基本使用

  1. 安装转码规则

    ES2015转码规则

    $ npm install --save-dev babel-preset-es2015

    react转码规则

    $ npm install --save-dev babel-preset-react

    ES7不同阶段语法提案的转码规则(共有4个阶段),选装一个

    $ npm install --save-dev babel-preset-stage-0

    $ npm install --save-dev babel-preset-stage-1

    $ npm install --save-dev babel-preset-stage-2

    $ npm install --save-dev babel-preset-stage-3

  2. 配置.babelrc文件

    {

    "presets": [

    "es2015",

    "react",

    "stage-2"

    ],

    "plugins": []

    }

  3. babel-cli使用

    //安装

    $ npm install --global babel-cli

    转码结果输出到标准输出

    $ babel example.js

    转码结果写入一个文件

    --out-file 或 -o 参数指定输出文件

    $ babel example.js --out-file compiled.js

    或者

    $ babel example.js -o compiled.js

    整个目录转码

    --out-dir 或 -d 参数指定输出目录

    $ babel src --out-dir lib

    或者

    $ babel src -d lib

    -s 参数生成source map文件

    $ babel src -d lib -s

  4. babel-node使用

    babel-cli工具自带一个babel-node命令,提供一个支持ES6的REPL环境。它支持Node的REPL环境的所有功能,而且可以直接运行ES6代码。

    $ babel-node es6.js

    2

  5. babel-register使用

    babel-register模块改写require命令,为它加上一个钩子。此后,每当使用require加载.js、.jsx、.es和.es6后缀名的文件,就会先用Babel进行转码。

    需要注意的是,babel-register只会对require命令加载的文件转码,而不会对当前文件转码。另外,由于它是实时转码,所以只适合在开发环境使用。

    //安装

    $ npm install --save-dev babel-register

    //例子

    require("babel-register");

    require("./index.js");

  6. babel-core使用

    如果某些代码需要调用Babel的API进行转码,就要使用babel-core模块。

    //安装

    $ npm install babel-core --save

    //例子

    var babel = require('babel-core');

    // 字符串转码

    babel.transform('code();', options);

    // => { code, map, ast }

    // 文件转码(异步)

    babel.transformFile('filename.js', options, function(err, result) {

    result; // => { code, map, ast }

    });

    // 文件转码(同步)

    babel.transformFileSync('filename.js', options);

    // => { code, map, ast }

    // Babel AST转码

    babel.transformFromAst(ast, code, options);

    // => { code, map, ast }

  7. babel-polyfill使用

    Babel默认只转换新的JavaScript句法(syntax),而不转换新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比 如Object.assign)都不会转码。举例来说,ES6在Array对象上新增了Array.from方法。Babel就不会转码这个方法。如果想让这个方法运行,必须使用babel-polyfill,为当前环境提供一个垫片。

    $ npm install --save babel-polyfill

    import 'babel-polyfill';

    // 或者

    require('babel-polyfill');

  8. 与其他工具配合使用

    mocha

    "scripts": {

    "test": "mocha --ui qunit --compilers js:babel-core/register"

    }

es6转码器-babel的更多相关文章

  1. ES6转码器babel的使用

    1. 进入ES6的项目,执行 npm init // 初始化package.json 2. 在与package.json同一目录下编写配置文件 .babelrc { "presets&quo ...

  2. 安装es6转码工具babel,具体步骤

    新建文件夹:testBabel 全局安装Babel:npm install babel-cli -g //babel的命令会成为全局变量,可以直接使用,一般全局后还要装本地(本工程目录) 初始化:np ...

  3. ES6标准简介之Babel转码器解说

    ES6是ECMAScript 6的简称,是JavaScript语言的下一代标准,现在基于jquery库的前端开发js所使用的标准是ES5(ECMAScript 5).ES6已于2015年6月正式发布. ...

  4. 使用babel转码器,让浏览器支持es6语法

    ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,可是很多浏览器并不支持es6语法,所以我们需要一个转码工具, 把es6的语法转换成浏览器支持的javascr ...

  5. Babel转码器

    Babel是一个广泛使用的ES6转码器,可以将ES6代码转为ES5代码,从而在现有环境执行.这意味着,你可以用ES6的方法 编写程序,又不用担心现在环境是否支持.

  6. Babel 转码器 § es6转换es5

    Babel 转码器 § es6转换es5 实时转码 /  Repl  -babel-node / babel-register(自动转码引入babel-register模块) 配置文件.babelrc ...

  7. ES6入门一:ES6简介及Babel转码器

    ES6简介 Babel转码器 Nodejs中使用ES6 WebPack中使用ES6及Babel转码插件 一.ES6简介与转码  1.1一个常见的问题,ECMAScript和JavaScript到底是什 ...

  8. ES6转ES5(Babel转码器)

    ES6转ES5(Babel转码器) 前提:必须在VScode中已经安装了Node.js 官网:https://nodejs.org/en/ 一.安装命令行转码工具 npm install --glob ...

  9. es6 babel转码器安装配置及常见命令

    示例:在d盘,新建文件夹es6,文件夹里新建一个文件es6.js. (1)先全局安装babel-cli,输入命令npm install babel-cli -g (2)输入d:( 进入d盘),再输入c ...

随机推荐

  1. As of ADT 14, resource fields cannot be used as switch cases

        在导入Android Sample的ApiDemos的时候,发现R.id.xx的文件不能够在 switch cases 中使用 在google查询了下,找到以下答案: As of ADT 14 ...

  2. UVa 12174 (滑动窗口) Shuffle

    首先预处理一下以每个数为结尾的前s个数是否能构成一个1~s的排列. 可以用cnt数组来记录每个数出现的次数和用一个变量记录一共有多少个不同的数出现. 然后枚举每种可能的情况,也就是枚举第一首歌会出现的 ...

  3. UVa 10115 Automatic Editing

    字符串题目就先告一段落了,又是在看balabala不知道在说些什么的英语. 算法也很简单,用了几个库函数就搞定了.本来还担心题里说的replace-by为空的特殊情况需要特殊处理,后来发现按一般情况处 ...

  4. java之IO

    IO流主要用于硬板.内存.键盘等处理设备上得数据操作 一.IO流分类 java.io包中定义了多个流类型(类或抽象类)来实现输入/输出功能,可以从不同角度对其分类: 1.按数据流的方向不同分为:输入流 ...

  5. mac 安装使用 webp 来压缩图片

    学习性网站: https://developers.google.com/speed/webp/docs/cwebp http://www.w3ctech.com//topic/1672 https: ...

  6. 【C#学习笔记】Hello World

    using System; namespace ConsoleApplication { class Program { static void Main(string[] args) { Conso ...

  7. 【英语】Bingo口语笔记(45) - Pass系列

  8. 决定undo表空间的大小

    1.查询每秒最高需要的undo的数据块[每个块8k大小] sys)) from v$undostat; )) --------------------------------------------- ...

  9. Java中Enum枚举的使用

    三种不同的用法 注意项: 1.在switch中使用枚举能使代码的可读性更强.   2.如果要自定义方法,那么必须在enum实例序列的最后添加分号.而且Java要求必须先定义enum实例.   3.所有 ...

  10. http tcp联系区别

    术语TCP/IP代表传输控制协议/网际协议,指的是一系列协议.“IP”代表网际协议,TCP和UDP使用该协议从一个网络传送数据包到另一个网络.把IP想像成一种高速公路,它允许其它协议在上面行驶并找到到 ...