真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

babel可不可以將es6轉(zhuǎn)換為es5

這篇文章主要介紹了babel可不可以將es6轉(zhuǎn)換為es5的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇babel可不可以將es6轉(zhuǎn)換為es5文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

創(chuàng)新互聯(lián)專注于訥河網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供訥河營(yíng)銷型網(wǎng)站建設(shè),訥河網(wǎng)站制作、訥河網(wǎng)頁(yè)設(shè)計(jì)、訥河網(wǎng)站官網(wǎng)定制、微信小程序開發(fā)服務(wù),打造訥河網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供訥河網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。

可以,轉(zhuǎn)換方法:1、在項(xiàng)目根目錄下執(zhí)行“npm install -g babel-cli --save-dev”命令將Babel安裝到項(xiàng)目中,將Babel配置文件“.babelrc”存放在項(xiàng)目的根目錄下,并設(shè)定轉(zhuǎn)碼規(guī)則即可;2、在項(xiàng)目中安裝gulp和gulp-babel,配置“gulpfile.js”文件即可。

當(dāng)我們還在沉迷于ES5的時(shí)候,殊不知ES6早就已經(jīng)發(fā)布幾年了。時(shí)代在進(jìn)步,WEB前端技術(shù)也在日新月異,是時(shí)候做些改變了!

ECMAScript 6(ES6)的發(fā)展速度非常之快,但現(xiàn)代瀏覽器對(duì)ES6新特性支持度不高,所以要想在瀏覽器中直接使用ES6的新特性就得借助別的工具來(lái)實(shí)現(xiàn)。
Babel是一個(gè)廣泛使用的轉(zhuǎn)碼器,babel可以將ES6代碼完美地轉(zhuǎn)換為ES5代碼,所以我們不用等到瀏覽器的支持就可以在項(xiàng)目中使用ES6的特性。

babel 6與之前版本的區(qū)別:

之前版本只要安裝一個(gè)babel就可以用了,所以之前的版本包含了一大堆的東西,這也導(dǎo)致了下載一堆不必要的東西。但在babel 6中,將babel拆分成兩個(gè)包:babel-cli和babel-core。如果你想要在CLI(終端或REPL)使用babel就下載babel-cli,如果想要在node中使用就下載babel-core。 babel 6已結(jié)盡可能的模塊化了,如果還用babel 6之前的方法轉(zhuǎn)換ES6,它會(huì)原樣輸出,并不會(huì)轉(zhuǎn)化,因?yàn)樾枰惭b插件。如果你想使用箭頭函數(shù),那就得安裝箭頭函數(shù)插件npm install  babel-plugin-transform-es2015-arrow-functions。

本文中,我們不討論ES6的語(yǔ)法特性,重點(diǎn)講的是如何將ES6代碼轉(zhuǎn)碼為ES5代碼。

Babel轉(zhuǎn)碼:

如果你并沒有接觸過(guò)ES6,當(dāng)你看到下面的代碼時(shí),肯定是有點(diǎn)懵逼的(這是什么鬼?心中一萬(wàn)頭神獸奔騰而過(guò)),但是你沒看錯(cuò),這就是ES6。不管你看不看它,它都在這里。

var a = (msg) => () => msg;
 
var bobo = {
  _name: "BoBo",
  _friends: [],
  printFriends() {
    this._friends.forEach(f =>
      console.log(this._name + " knows " + f));
  }
};

實(shí)際上,上面的這段代碼通過(guò)Babel轉(zhuǎn)換后,會(huì)變成:

"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);
    });
  }
};

好,言歸正傳,我們嘗試下用一些方法來(lái)實(shí)現(xiàn)上面的轉(zhuǎn)碼效果吧。

1、直接安裝Babel法:

1.1) 首先全局安裝Babel。

$ npm install -g babel-cli
 
//也可以通過(guò)直接將Babel安裝到項(xiàng)目中,在項(xiàng)目根目錄下執(zhí)行下面命令,同時(shí)它會(huì)自動(dòng)在package.json文件中的devDependencies中加入babel-cli
//在執(zhí)行安裝到項(xiàng)目中命令之前,要先在項(xiàng)目根目錄下新建一個(gè)package.json文件。
$ npm install -g babel-cli --save-dev

如果將babel直接安裝到項(xiàng)目中,它會(huì)自動(dòng)在package.json文件中的devDependencies中加入babel-cli。如下所示:

	//......
	{
	  "devDependencies": {
	    "babel-cli": "^6.22.2"
	  }
	}

1.2) Babel的配置文件是.babelrc,存放在項(xiàng)目的根目錄下。使用Babel的第一步,就是配置這個(gè)文件。

這個(gè)文件的完整文件名是 “.babelrc”,注意最前面是有個(gè)“.”的。由于我的電腦是Windows系統(tǒng),所以在新建這個(gè)文件的時(shí)候老是提示 “必須鍵入文件名” 的錯(cuò)誤。后來(lái)谷歌了下,發(fā)現(xiàn)創(chuàng)建這個(gè)文件的時(shí)候,把文件名改成“.babelrc.”,注意是前后都有一個(gè)點(diǎn),這樣就可以保存成功了

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

1.3) presets字段設(shè)定轉(zhuǎn)碼規(guī)則,官方提供以下的規(guī)則集,你可以根據(jù)需要安裝。

點(diǎn)擊此處到Babel中文官網(wǎng)presets配置頁(yè)面:Babel Plugins

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

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

	# ES7不同階段語(yǔ)法提案的轉(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

1.4) 根據(jù)官網(wǎng)的提示,當(dāng)我們用npm安裝好這些插件工具之后,我們需要將這些規(guī)則加入到.babelrc中去。如下所示:

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

1.5) 轉(zhuǎn)碼、轉(zhuǎn)碼的規(guī)則:

	# 轉(zhuǎn)碼結(jié)果輸出到標(biāo)準(zhǔn)輸出
	$ babel test.js

	# 轉(zhuǎn)碼結(jié)果寫入一個(gè)文件
	# --out-file 或 -o 參數(shù)指定輸出文件
	$ babel a.js --out-file b.js
	# 或者
	$ babel a.js -o b.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、工具配置法:

實(shí)際上,我們可以通過(guò)前端自動(dòng)化的很多工具來(lái)實(shí)現(xiàn)ES6的轉(zhuǎn)碼配置,比如,常見的grunt、gulp、Webpack和Node等。下面我就簡(jiǎn)單的說(shuō)下我較為熟悉的gulp配置法。

點(diǎn)擊此處到Babel中文官網(wǎng)Tool配置頁(yè)面:Babel Tool

2.1) 首先,我們需要在項(xiàng)目中安裝gulp:

	$ npm install gulp --save-dev

2.2) 然后,我們需要在項(xiàng)目中安裝gulp-babel:

	$ npm install --save-dev gulp-babel

當(dāng)執(zhí)行完上面的兩個(gè)命令后,我們會(huì)發(fā)現(xiàn)根目錄下的package.json文件內(nèi)容已經(jīng)被自動(dòng)修改成:

	{
	  "devDependencies": {
	    "babel-cli": "^6.22.2",
	    "gulp": "^3.9.1",
	    "gulp-babel": "^6.1.2"
	  }
	}

2.3) 編寫gulpfile.js文件,文件內(nèi)容如下所示:

	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"));
	});

當(dāng)我們?cè)诋?dāng)前項(xiàng)目目錄下運(yùn)行如下命令后,會(huì)發(fā)現(xiàn)原本在src文件夾中的a.js(按照ES6標(biāo)準(zhǔn)編寫的)文件已經(jīng)被轉(zhuǎn)碼成ES5標(biāo)準(zhǔn)的a.js,并放在了lib文件夾里面。

	$ gulp default

	#或者用下面的命令也行
	$ gulp

關(guān)于“babel可不可以將es6轉(zhuǎn)換為es5”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“babel可不可以將es6轉(zhuǎn)換為es5”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


新聞名稱:babel可不可以將es6轉(zhuǎn)換為es5
本文來(lái)源:http://weahome.cn/article/jhpgjd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部