亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

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

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

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

    前端(vue)入門到精通課程:進入學(xué)習(xí)
    Apipost = Postman + Swagger + Mock + Jmeter 超好用的API調(diào)試工具:點擊使用

    本教程操作環(huán)境:windows7系統(tǒng)、ECMAScript 6&&babel 6版、Dell G3電腦。

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

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

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

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

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

    Babel轉(zhuǎn)碼:

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

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

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

    "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);     });   } };
    登錄后復(fù)制

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

    1、直接安裝Babel法:

    1.1) 首先全局安裝Babel。

    $ npm install -g babel-cli   //也可以通過直接將Babel安裝到項目中,在項目根目錄下執(zhí)行下面命令,同時它會自動在package.json文件中的devDependencies中加入babel-cli //在執(zhí)行安裝到項目中命令之前,要先在項目根目錄下新建一個package.json文件。 $ npm install -g babel-cli --save-dev
    登錄后復(fù)制

    如果將babel直接安裝到項目中,它會自動在package.json文件中的devDependencies中加入babel-cli。如下所示:

    	//...... 	{ 	  "devDependencies": { 	    "babel-cli": "^6.22.2" 	  } 	}
    登錄后復(fù)制

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

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

    	{ 	  "presets": [], 	  "plugins": [] 	}
    登錄后復(fù)制

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

    點擊此處到Babel中文官網(wǎng)presets配置頁面: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不同階段語法提案的轉(zhuǎn)碼規(guī)則(共有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
    登錄后復(fù)制

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

    	{ 	    "presets": [ 	      "es2015", 	      "react", 	      "stage-2" 	    ], 	    "plugins": [] 	  }
    登錄后復(fù)制

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

    	# 轉(zhuǎn)碼結(jié)果輸出到標(biāo)準(zhǔn)輸出 	$ babel test.js  	# 轉(zhuǎn)碼結(jié)果寫入一個文件 	# --out-file 或 -o 參數(shù)指定輸出文件 	$ babel a.js --out-file b.js 	# 或者 	$ babel a.js -o b.js  	# 整個目錄轉(zhuǎn)碼 	# --out-dir 或 -d 參數(shù)指定輸出目錄 	$ babel src --out-dir lib 	# 或者 	$ babel src -d lib  	# -s 參數(shù)生成source map文件 	$ babel src -d lib -s
    登錄后復(fù)制

    2、工具配置法:

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

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

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

    	$ npm install gulp --save-dev
    登錄后復(fù)制

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

    	$ npm install --save-dev gulp-babel
    登錄后復(fù)制

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

    	{ 	  "devDependencies": { 	    "babel-cli": "^6.22.2", 	    "gulp": "^3.9.1", 	    "gulp-babel": "^6.1.2" 	  } 	}
    登錄后復(fù)制

    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")); 	});
    登錄后復(fù)制

    當(dāng)我們在當(dāng)前項目目錄下運行如下命令后,會發(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
    登錄后復(fù)制

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號