您好,登錄后才能下訂單哦!
這篇文章主要介紹了babel可不可以將es6轉換為es5的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇babel可不可以將es6轉換為es5文章都會有所收獲,下面我們一起來看看吧。
可以,轉換方法:1、在項目根目錄下執行“npm install -g babel-cli --save-dev”命令將Babel安裝到項目中,將Babel配置文件“.babelrc”存放在項目的根目錄下,并設定轉碼規則即可;2、在項目中安裝gulp和gulp-babel,配置“gulpfile.js”文件即可。
當我們還在沉迷于ES5的時候,殊不知ES6早就已經發布幾年了。時代在進步,WEB前端技術也在日新月異,是時候做些改變了!
ECMAScript 6(ES6)的發展速度非常之快,但現代瀏覽器對ES6新特性支持度不高,所以要想在瀏覽器中直接使用ES6的新特性就得借助別的工具來實現。
Babel是一個廣泛使用的轉碼器,babel可以將ES6代碼完美地轉換為ES5代碼,所以我們不用等到瀏覽器的支持就可以在項目中使用ES6的特性。
babel 6與之前版本的區別:
之前版本只要安裝一個babel就可以用了,所以之前的版本包含了一大堆的東西,這也導致了下載一堆不必要的東西。但在babel 6中,將babel拆分成兩個包:babel-cli和babel-core。如果你想要在CLI(終端或REPL)使用babel就下載babel-cli,如果想要在node中使用就下載babel-core。 babel 6已結盡可能的模塊化了,如果還用babel 6之前的方法轉換ES6,它會原樣輸出,并不會轉化,因為需要安裝插件。如果你想使用箭頭函數,那就得安裝箭頭函數插件npm install babel-plugin-transform-es2015-arrow-functions。
本文中,我們不討論ES6的語法特性,重點講的是如何將ES6代碼轉碼為ES5代碼。
Babel轉碼:
如果你并沒有接觸過ES6,當你看到下面的代碼時,肯定是有點懵逼的(這是什么鬼?心中一萬頭神獸奔騰而過),但是你沒看錯,這就是ES6。不管你看不看它,它都在這里。
var a = (msg) => () => msg;
var bobo = {
_name: "BoBo",
_friends: [],
printFriends() {
this._friends.forEach(f =>
console.log(this._name + " knows " + f));
}
};
實際上,上面的這段代碼通過Babel轉換后,會變成:
"use strict";
var a = function a(msg) {
return function () {
return msg;
};
};
var bobo = {
_name: "BoBo",
_friends: [],
printFriends: function printFriends() {
var _this = this;
this._friends.forEach(function (f) {
return console.log(_this._name + " knows " + f);
});
}
};
好,言歸正傳,我們嘗試下用一些方法來實現上面的轉碼效果吧。
1、直接安裝Babel法:
1.1) 首先全局安裝Babel。
$ npm install -g babel-cli
//也可以通過直接將Babel安裝到項目中,在項目根目錄下執行下面命令,同時它會自動在package.json文件中的devDependencies中加入babel-cli
//在執行安裝到項目中命令之前,要先在項目根目錄下新建一個package.json文件。
$ npm install -g babel-cli --save-dev
如果將babel直接安裝到項目中,它會自動在package.json文件中的devDependencies中加入babel-cli。如下所示:
//......
{
"devDependencies": {
"babel-cli": "^6.22.2"
}
}
1.2) Babel的配置文件是.babelrc,存放在項目的根目錄下。使用Babel的第一步,就是配置這個文件。
這個文件的完整文件名是 “.babelrc”,注意最前面是有個“.”的。由于我的電腦是Windows系統,所以在新建這個文件的時候老是提示 “必須鍵入文件名” 的錯誤。后來谷歌了下,發現創建這個文件的時候,把文件名改成“.babelrc.”,注意是前后都有一個點,這樣就可以保存成功了
{
"presets": [],
"plugins": []
}
1.3) presets字段設定轉碼規則,官方提供以下的規則集,你可以根據需要安裝。
點擊此處到Babel中文官網presets配置頁面:Babel Plugins
# 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
1.4) 根據官網的提示,當我們用npm安裝好這些插件工具之后,我們需要將這些規則加入到.babelrc中去。如下所示:
{
"presets": [
"es2015",
"react",
"stage-2"
],
"plugins": []
}
1.5) 轉碼、轉碼的規則:
# 轉碼結果輸出到標準輸出
$ babel test.js
# 轉碼結果寫入一個文件
# --out-file 或 -o 參數指定輸出文件
$ babel a.js --out-file b.js
# 或者
$ babel a.js -o b.js
# 整個目錄轉碼
# --out-dir 或 -d 參數指定輸出目錄
$ babel src --out-dir lib
# 或者
$ babel src -d lib
# -s 參數生成source map文件
$ babel src -d lib -s
2、工具配置法:
實際上,我們可以通過前端自動化的很多工具來實現ES6的轉碼配置,比如,常見的grunt、gulp、Webpack和Node等。下面我就簡單的說下我較為熟悉的gulp配置法。
點擊此處到Babel中文官網Tool配置頁面:Babel Tool
2.1) 首先,我們需要在項目中安裝gulp:
$ npm install gulp --save-dev
2.2) 然后,我們需要在項目中安裝gulp-babel:
$ npm install --save-dev gulp-babel
當執行完上面的兩個命令后,我們會發現根目錄下的package.json文件內容已經被自動修改成:
{
"devDependencies": {
"babel-cli": "^6.22.2",
"gulp": "^3.9.1",
"gulp-babel": "^6.1.2"
}
}
2.3) 編寫gulpfile.js文件,文件內容如下所示:
var gulp = require("gulp");
var babel = require("gulp-babel");
gulp.task("default", function () {
return gulp.src("src/a.js")
.pipe(babel())
.pipe(gulp.dest("lib"));
});
當我們在當前項目目錄下運行如下命令后,會發現原本在src文件夾中的a.js(按照ES6標準編寫的)文件已經被轉碼成ES5標準的a.js,并放在了lib文件夾里面。
$ gulp default
#或者用下面的命令也行
$ gulp
關于“babel可不可以將es6轉換為es5”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“babel可不可以將es6轉換為es5”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。