babel本地编辑环境搭建

babel本地编辑环境搭建

今天讲的是babel搭建本地环境,众所周知,现如今,javascript已经发布了es7版本,但是目前环境大多数只能支持到es5,连nodejs也不能完全支持es6,es7。今天将的babel能将我们写的es6,es7的代码转换成es5,从而让现有环境能好好运行我们的js。

1.babel安装

babel是通过npm安装的,npm是node上的一个模块,所以环境要求,先要安装node.js,然后安装npm,之后再安装babel-cli(babel命令行工具)。选择对应的版本安装,最新版的内置了npm模块。

node上传

查看版本node和npm版本号:

查看版本

babel-cli安装,国内环境建议将npm的源缓存淘宝的再安装。

npm config set registry https://registry.npm.taobao.org/
npm config get registry

输入npm install babel-cli -g来全局安装babel-cli,然后查看到了版本表示安装成功了。

npm install babel-cli -g
babel -V
babel安装成功

2.使用

我们先找一个目录,然后用npm来初始化一个项目,用来搭建我们的babel环境。

搭建

我们进到刚才的babel目录,然后打开命令行工具输入一些命令来验证一下我们的环境。

babel-node
(a => a + 1)(2)
3
编译

可以看到,上面我们顺利执行了一个es6的箭头函数。这里babel-node是babel提供的一个编译工具,可以采用命令行方式执行我们的js代码,下面我们在用babel-node执行一个js文件。我们进入工程目录babel并新建index.js,并输入以下代码。

let a = [1,2,3];
a.map((row) => {
    console.log(row)
})

然后在命令行输入以下命令。


执行js

可以看到,babel-node运行了我们es6的代码。下面将通过一些配置,来完善我们的babel环境。

3配置

我们在babel目录新建.babelrc,Windows下可以用如下命令创建。

echo. > .babelrc

用记事本打开,输入以下内容

{
    "presets": ["es2015", "stage-2"],  //设置转码规则
    "plugins": ["transform-runtime"]  //设置插件
 }

这里我们配置好了babel的转码规则,转码成es2015.官方提供以下的规则集,可以根据需要安装:

# 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

这里我们只需要转换成es2015,这里我们安装我们需要的部分:
npm install babel-core babel-preset-es2015 babel-plugin-transform-runtime babel-preset-stage-2 --save-dev
,如需其他配置,可以修改.babelrc文件,然后安装上面对于的插件。我们再打开我们babel项目下的package.json文件,做如下修改。

{
  "name": "babel",
  "version": "1.0.0",
  "description": "a babel project",
  "main": "index.js",
  "scripts": {
    "build": "babel src -w -d lib" 
    //编译整个 src 目录并将其输出到 lib 目录。这里的src指的是需要转换的目录,lib指的是输出的内容的存放目录,-w其实是-watch的意思,就是监听文件,实时编译输出
  },
  "keywords": [
    "babel"
  ],
  "devDependencies": {
    "babel-core": "^6.26.3",
    "babel-plugin-transform-runtime": "^6.23.0",
    "babel-preset-es2015": "^6.24.1",
    "babel-preset-stage-2": "^6.24.1"
  }
  "author": "zhujie",
  "license": "ISC"
}

现在我们在babel工程目录下新建src目录和lib目录,记得一定要建,不然会报错,然后我们启动我们的babel工程。命令号输入npm run build。这样就启动了我们的babel实时编译功能。这里可以是在在src目录新建main.js,然后输入

//异步加载图片
let d;
function loadImageAsync(url){
    return new Promise((resolve,reject) => {
        const image = new Image();
        image.onload = function(){
            resolve(image);
        };
        image.onerror = function(){
            reject(new Error('error'));
        }
        image.src = url;
    });
}

然后我们打开lib目录下的mina.js,可以看到代码已经被转换。

'use strict';

var _promise = require('babel-runtime/core-js/promise');

var _promise2 = _interopRequireDefault(_promise);

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }

//异步加载图片
var d = void 0;
function loadImageAsync(url) {
    return new _promise2.default(function (resolve, reject) {
        var image = new Image();
        image.onload = function () {
            resolve(image);
        };
        image.onerror = function () {
            reject(new Error('error'));
        };
        image.src = url;
    });
}

大功告成!

总结

文中搭建了一个babel能转换es6,es7语法的工程,适应大多数环境,对于不想有太多累赘,仅仅想使用es6,es7语法的情况下是够用的,但是babel其实还有很多功能,babel-register,babel-core,babel-polyfill等工具。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容

  • 一、ES6 参考 http://es6.ruanyifeng.com/ ECMAScript当前所有提案 Git...
    pifoo阅读 11,835评论 1 13
  • ES6其实就是javascript的升级版。有些浏览器已经慢慢支持ES6,或者在node的环境下也可以支持ES6,...
    meiziLin阅读 764评论 0 1
  • 随着es6,es7,es8等新标准的出现,我们在项目中为了更好的体验和使用这些新特性,但是在浏览器中又不能直接运行...
    梦想成真213阅读 2,936评论 0 2
  • 前提是已经安装了node环境。 一:新建目录(babel-es6) 二:安装babel环境依赖 npm insta...
    __Object__阅读 119评论 0 0
  • 一、说明es6跟es5不同的是,es6需要搭建环境,不像es5那样直接就可以编写运行,因为有些浏览器还是不支持es...
    小丘啦啦啦阅读 1,684评论 0 1