美文网首页babel
2.Babel转码器

2.Babel转码器

作者: 蛐蛐_ | 来源:发表于2017-01-13 10:43 被阅读44次

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

// 转码前
input.map(item => item + 1);
// 转码后
input.map(function (item) {
        return item + 1;
 });

上面的原始代码用了箭头函数,这个特性还没有得到广泛支持,Babel将其转为普通函数,就能在现有的JavaScript环境执行了。

配置文件.babelrc
Babel的配置文件是.babelrc,存放在项目的根目录下。使用Babel的第一步,就是配置这个文件。
该文件用来设置转码规则和插件,基本格式如下。

    { 
      "presets": [],
      "plugins": []
    }```

```presets```
字段设定转码规则,官方提供以下的规则集,你可以根据需要安装。
***

.# 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
然后,将这些规则加入.babelrc

{
 "presets": [ 
 "es2015",
 "react",
 "stage-2" 
 ],
 "plugins": []
 }

注意,以下所有Babel工具和模块的使用,都必须先写好.babelrc

1.命令行转码babel-cli

Babel提供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

上面代码是在全局环境下,进行Babel转码。这意味着,如果项目要运行,全局环境必须有Babel,也就是说项目产生了对环境的依赖。另一方面,这样做也无法支持不同项目使用不同版本的Babel。
一个解决办法就是将 babel-cli安装在项目之中。
.#安装

$ npm install --save-dev babel-cli

然后,改写package.json

{  // ...
 "devDependencies": { 
"babel-cli": "^6.0.0"
 },
 "scripts": { 
"build": "babel src -d lib" 
  },
}

转码的时候,就执行下面的命令。

$ npm run build

2.babel-node

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

它不用单独安装,而是随babel-cli一起安装。然后,执行babel-node就进入REPL环境。
$ babel-node
> (x => x * 2)(1)2

babel-node
命令可以直接运行ES6脚本。将上面的代码放入脚本文件es6.js
,然后直接运行。
$ babel-node es6.js2
babel-node
也可以安装在项目中。

$ npm install --save-dev babel-cli

然后,改写package.json。

{
 "scripts": { 
"script-name": "babel-node script.js"
 }
}

上面代码中,使用babel-node替代node,这样script.js本身就不用做任何转码处理。


3.babel-register

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

require("babel-register");
require("./index.js");

然后,就不需要手动对index.js转码了。

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

相关文章

  • 2.Babel转码器

    Babel是一个广泛使用的ES6转码器,可以将ES6代码转为ES5代码,从而在现有环境执行。这意味着,你可以用ES...

  • 合格的全栈前端要掌握的前端知识

    1.webpack 打包所有的脚本 2.babel javascript的语法编译器 3.nodejs 前端工程化...

  • babel 转码器

    Babel介绍 Babel 是一个广泛使用的 ES6 转码器,可以将 ES6 代码转为 ES5 代码,从而在现有环...

  • Babel 转码器

    Babel 是一个广泛使用的 ES6 转码器,可以将 ES6 代码转为 ES5 代码,从而在现有环境执行。这意味着...

  • babel转码器

    npm install--save-dev @babel/core es6=>es5 箭头函数转为普通函数 bab...

  • babel转码器

    cnpm安装插件出现的问题 上面说 object-visit@^1.0.0 不兼容win32位系统,其实是因为 b...

  • Babel 转码器

    Babel[https://babeljs.io/] 是一个广泛使用的 ES6 转码器,可以将 ES6 代码转为 ...

  • ECMAScript 6 入门 作者:阮一峰

    ECMAScript 6 简介 【摘录】es6可以用转码器转码为es5 let和const 【摘录】let用来声明...

  • ES6标准入门0-50页

    1.6 Babel转码器 Babel是一个广为使用的ES6转码器,可以将ES6代码转换为ES5代码,从而在浏览器或...

  • js转化html字符

    /*1.用浏览器内部转换器实现html转码*/ htmlEncode:function (html...

网友评论

    本文标题:2.Babel转码器

    本文链接:https://www.haomeiwen.com/subject/zuojbttx.html