Babel 入門

Babel是一個(gè)廣泛使用的轉(zhuǎn)碼器班套,可以將ES6代碼轉(zhuǎn)為ES5代碼,從而在現(xiàn)有環(huán)境執(zhí)行坦康。

官方手冊(cè)傳送門

https://github.com/thejameskyle/babel-handbook/blob/master/translations/zh-Hans/user-handbook.md

不建議進(jìn)行全局安裝惨奕,這樣可以保證各個(gè)項(xiàng)目獨(dú)立環(huán)境。

1.安裝

全局安裝

npm install -g babel
npm install -g babel-cli

局部安裝

npm install  --save-dev babel
npm install --save-dev babel-cli

babel6之后 分離為多個(gè)包
babel-cli 命令行
babel-core node api 以及 require hook
babel-polyfill 提供es2015的環(huán)境

轉(zhuǎn)化為ES5等需要安裝插件,根據(jù)需要安裝

# ES2015轉(zhuǎn)碼規(guī)則
$ npm install --save-dev babel-preset-es2015

# react轉(zhuǎn)碼規(guī)則
$ npm install --save-dev babel-preset-react

# ES7不同階段語法提案的轉(zhuǎn)碼規(guī)則(共有4個(gè)階段)馆匿,選裝一個(gè)
$ 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.使用

2.1命令行轉(zhuǎn)化js文件:

babel es6.js  --presets es2015

轉(zhuǎn)碼結(jié)果輸出到命令行

2.2轉(zhuǎn)碼結(jié)果寫入一個(gè)文件

# 轉(zhuǎn)碼結(jié)果寫入一個(gè)文件
# --out-file 或 -o 參數(shù)指定輸出文件
$ babel example.js --out-file compiled.js
# 或者
$ babel example.js -o compiled.js

# 整個(gè)目錄轉(zhuǎn)碼
# --out-dir 或 -d 參數(shù)指定輸出目錄
$ babel src --out-dir lib
# 或者
$ babel src -d lib

# -s 參數(shù)生成source map文件
$ babel src -d lib -s

2.3在項(xiàng)目中可以通過修改 package.json 文件

{
  "name": "my-project",
  "version": "1.0.0",
  "devDependencies": {
    "babel-cli": "^6.0.0"
  }
}

現(xiàn)在抑胎,我們不直接從命令行運(yùn)行 Babel 了,取而代之我們將把運(yùn)行命令寫在 npm scripts 里渐北,這樣可以使用 Babel 的本地版本阿逃。
只需將 "scripts" 字段添加到你的 package.json 文件內(nèi)并且把 babel 命令寫成 build 字段。.

{
    "name": "my-project",
    "version": "1.0.0",
+   "scripts": {
+     "build": "babel src -d lib"
+   },
    "devDependencies": {
      "babel-cli": "^6.0.0"
    }
  }

現(xiàn)在可以在終端里運(yùn)行:

npm run build

這將以與之前同樣的方式運(yùn)行 Babel,但這一次我們使用的是本地副本恃锉。

3.配置.babelrc配置文件

Babel的配置文件是.babelrc搀菩,存放在項(xiàng)目的根目錄下。使用Babel的第一步破托,就是配置這個(gè)文件肪跋。
該文件用來設(shè)置轉(zhuǎn)碼規(guī)則和插件,基本格式如下炼团。

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

然后澎嚣,將這些規(guī)則加入.babelrc。

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

4.babel-polyfill

Babel默認(rèn)只轉(zhuǎn)換新的JavaScript句法(syntax)瘟芝,而不轉(zhuǎn)換新的API易桃,比如Iterator、Generator锌俱、Set晤郑、Maps、Proxy贸宏、Reflect造寝、Symbol、Promise等全局對(duì)象吭练,以及一些定義在全局對(duì)象上的方法(比如Object.assign)都不會(huì)轉(zhuǎn)碼诫龙。
舉例來說,ES6在Array對(duì)象上新增了Array.from方法鲫咽。Babel就不會(huì)轉(zhuǎn)碼這個(gè)方法签赃。如果想讓這個(gè)方法運(yùn)行,必須使用babel-polyfill分尸,為當(dāng)前環(huán)境提供一個(gè)墊片锦聊。
Babel默認(rèn)不轉(zhuǎn)碼的API非常多,詳細(xì)清單可以查看babel-plugin-transform-runtime
模塊的definitions.js文件箩绍。
安裝命令如下孔庭。

npm install --save babel-polyfill

然后只需要在文件頂部導(dǎo)入 polyfill 就可以了:

import "babel-polyfill";
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市材蛛,隨后出現(xiàn)的幾起案子圆到,更是在濱河造成了極大的恐慌,老刑警劉巖卑吭,帶你破解...
    沈念sama閱讀 222,590評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件构资,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡陨簇,警方通過查閱死者的電腦和手機(jī)吐绵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門迹淌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人己单,你說我怎么就攤上這事唉窃。” “怎么了纹笼?”我有些...
    開封第一講書人閱讀 169,301評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵纹份,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我廷痘,道長(zhǎng)蔓涧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,078評(píng)論 1 300
  • 正文 為了忘掉前任笋额,我火速辦了婚禮元暴,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘兄猩。我一直安慰自己茉盏,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評(píng)論 6 398
  • 文/花漫 我一把揭開白布枢冤。 她就那樣靜靜地躺著鸠姨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪淹真。 梳的紋絲不亂的頭發(fā)上讶迁,一...
    開封第一講書人閱讀 52,682評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音核蘸,去河邊找鬼巍糯。 笑死,一個(gè)胖子當(dāng)著我的面吹牛值纱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播坯汤,決...
    沈念sama閱讀 41,155評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼虐唠,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了惰聂?” 一聲冷哼從身側(cè)響起疆偿,我...
    開封第一講書人閱讀 40,098評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎搓幌,沒想到半個(gè)月后杆故,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,638評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡溉愁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評(píng)論 3 342
  • 正文 我和宋清朗相戀三年处铛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,852評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡撤蟆,死狀恐怖奕塑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情家肯,我是刑警寧澤龄砰,帶...
    沈念sama閱讀 36,520評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站讨衣,受9級(jí)特大地震影響换棚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜反镇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評(píng)論 3 335
  • 文/蒙蒙 一固蚤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧愿险,春花似錦颇蜡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至扮叨,卻和暖如春缤弦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背彻磁。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工碍沐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人衷蜓。 一個(gè)月前我還...
    沈念sama閱讀 49,279評(píng)論 3 379
  • 正文 我出身青樓累提,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親磁浇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子斋陪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容