在線babel編譯
A. 原來Babel 能直接編譯 JSX.官方用的是哪個
習慣了WebStorm的話..我就假設題主會用Node.js和npm啦~一句話總結:用WebStorm自帶的FileWatcher功能+Babel實現自動轉換ECMAScript6代碼為ES5代碼我是這么配置的..就先新建一個EmptyProject,然後在src目錄下新建了一個main.js;//這一步不是必須的只是剛上手的話從空項目開始自己配置會少很多干擾Then..進入設置,把JavaScriptlanguageversion改成ECMAScript6;再Then..寫一段ES6代碼'usestrict';//node直接運行ES6代碼時,如使用了ES6的一些關鍵字,比如let,就需要嚴格模式,否則會報錯//這是沒有嚴格模式時候的錯誤提示//SyntaxError:Block-scopeddeclarations(let,const,function,class)*fibs(){//GeneratorFunctionleta=0;letb=1;while(true){yielda;//[a,b]=[b,a+b];b=a+b;a=b-a;}}let[first,second,third,fourth,fifth,sixth]=fibs();console.log(first,second,third,fourth,fifth,sixth);現在IDE會出現一個Filewatcher提示條先別點Addwatcher!我們要先去裝babel~首先在根目錄新建一個package.json{"name":"test-project","version":"1.0.0"}然後打開IDE的Terminal,安裝babel-clinpminstall--save-devbabel-cliGood!現在可以去點Addwatcher啦,點完之後會彈出一個框,其中大部分設置IDE都幫你搞定了下面第三行,Program那一項,填$ProjectFileDir$/node_moles/.bin/babel然後點OK,這個時候你就會發現左邊多出來一個main-compiled.js文件啦但是還沒搞定!現在只是搞定了自動轉換的功能,系統默認把ES6compile成了ES6..(你應該會發現compile出來的東西跟原來的一樣..Generator函數並沒有被轉換成ES5的格式)所以我們需要安裝Babel的preset以正確識別ES6代碼;和剛才一樣,在npm安裝babel的ES6的presetnpminstall--save-devbabel-preset-es2015在根目錄下新建一個.babelrc文件(就是babel在當前項目的配置文件),寫上{"presets":["es2015"]}OK搞定!保存再回去看一下main-compiled.js應該就變成這個樣子啦,現在你在main.js里直接寫ES6代碼,IDE都會自動compile成ES5的代碼在這里啦~注意:想直接用Node.js運行ES6代碼還是有些問題..因為這段代碼用的ES6的解構賦值Node.js還未完全支持,需要在運行的時候加入一些tags(以開啟Node.js的相關試驗特性),具體可以參考Node.js官網對ES6的說明:ECMAScript2015(ES6)。
B. 怎麼用webpack和babel編譯es6
首先無論require還是import,都不是webpack的發明,它們是已經存在於世的不同的模塊化規范(目前都不能直接運行於瀏覽器)。 於是需要通過webpack在配合各種plugin、loader將其轉義,使之可以運行在瀏覽器里。
C. gulp babel安裝成功了為什麼不能將es6編譯成es5
按babel官方教程來配置的:
gulpfile.js
var gulp = require("gulp");var babel = require("gulp-babel");
gulp.task("default", function () { return gulp.src("src/app.js")
.pipe(babel())
.pipe(gulp.dest("dist"));
});
app.js
'use strict';let a = 'hello world';
還需要安裝babel-preset-es2015插件,才能把es6編譯成es5
npm install --save-devbabel-preset-es2015
在gulpfile.js中增加presets
var gulp = require("gulp");var babel = require("gulp-babel");
gulp.task("default", function () { return gulp.src("src/app.js")
.pipe(babel({ presets: ['es2015']
}))
.pipe(gulp.dest("dist"));
});
D. 如何使用 babel在瀏覽器端使用
Babel是一個轉換編譯器,它能將ES6轉換成可以在瀏覽器中運行的代碼。Babel由來自澳大利亞的開發者Sebastian McKenzie創建。他的目標是使Babel可以處理ES6的所有新語法,並為它內置了React JSX擴展及Flow類型註解支持。 據codemix創始人Charles P...
E. 怎麼在webstorm上利用babel實現自動編譯es6文件
現階段,建議你直接考慮用gulp,利用gulp-babel轉es6。 畢竟一個團隊中不是每個人都是用的webstrom,還有畢竟後續es6不是你的唯一需求,比如你還需要webpack
現階段版本中轉es5後在IE8下還是有很多坑需要填,甚至有bug依然很難用常規手段解決,所以如果你們需要支持IE8不是很建議在實際項目中用babel。
F. 如何使用babel來進行語法的編譯在這里可以看得到
編譯器H Builder的語法應該是Visual Basic的基本語法。在Visual Basic中的基本語句包括:一、賦值語句。賦值語句的語法如下:變數名或對象.屬性=表達式它的含義是把等號右邊的值賦給等號左邊的值。二、判定結構。一、If語句。用If...Then結構有條件地執行一個或多個語句。單行語法和多行塊語法都可以使用: If condition Then statement If condition Then Statements End If Condition 通常是比較式,但它可以是任何計算數值的表達式。Visual Basic 將這個值解釋為True或False:一個為零的數值為False,而任何非零數值都被看作True。若condition為True,則Visual Basic執行Then 關鍵字後面的所有statements。可以使用單行或多行語法有條件地執行一個語句。注意:If...Then的單行格式不用End If語句。如果condition為True時要執行多行代碼,則必須使用多行塊If...Then...End If語法。二、If...Then...Else語句。用If...Then...Else塊定義幾個語句塊,執行其中一個語句: If condition1 Then [statementblock-1] [ElseIf condition2 Then [statementblock-2]] ... [Else [statementblock-n]] End If Visual Basic首先測試condition1。如果它為False,Visual Basic就測試 condition2,依次類推,直到找到一個為True的條件。當它找到一個為 True的條件時,Visual Basic就會執行相應的語句塊,然後執行End If後面的代碼。作為一個選擇,可以包含Else語句塊,如果條件都不是True,則Visual Basic執行Else語句塊。 If...Then…ElseIf只是If...Then...Else的一個特例。注意,可以使用任意數量的 ElseIf子句,或者一個也不用。可以有一個Else子句,而不管有沒有ElseIf 子句。二、循環語句。電腦最擅長的就是不厭其煩地重復做一項工作成千上萬遍(即重復執行幾行代碼),這就是通過循環結構來完成的。VB支持的循環結構有:Do…Loop和For…Next。用Do循環重復執行一個語句塊,且重復次數不定。Do…Loop是以計算數值為條件以決定是否繼續執行。條件必須是一個數值或者值為True或False的表達式。在下面的Do…Loop循環中,只要條件為真就執行循環。 Do While 循環條件循環語句塊 Loop 當Visual Basic執行到這個Do循環時首先測試條件,條件為假時,跳過所有語句。如果條件為真,Visual Basic就會執行語句,退回到Do While語句測試條件。只要條件為真,循環可以隨意執行幾次。如果條件一開始便為假,則不會執行語句。還有一種Do…Loop語句,是先執行語句,每次執行之後測試條件,循環中的語句至少執行一次。 Do 循環語句塊 Loop While 循環條件在不知道循環要執行幾次語句時,用Do循環,知道循環次數時,可以使用For…Next循環。For循環使用一個叫做計數器的變數,重復一次循環之後,計數器的值會增加或減少。 For 計數器=初值To終止值Step增量循環語句塊 Next 計數器計數器、初值、終止值和增量為數值型。執行For循環時,設置計數器等於初值,測試計數器是否大於終止值,是則退出循環,執行循環語句,計數器增加增量後重復以上步驟。用Exit語句可以退出For循環、Do循環,它的語法是Exit Do和Exit For,在循環中出現的次數無限制。
G. gulp-babel編譯es6後的require怎麼處理
gulp在3.9版本裡面增加了對babel的支持,因此我們可以直接在gulpfile裡面使用ES6(ES2015)了。 升級gulp版本 首先要檢測一下我們的gulp版本,確保CLI版本及Local版本都在3.9之上: gulp -v 版本如下
H. babel 編譯 jquery嗎
jquery不用去編譯吧 直接把寫的jq代碼 import到對應的 位置就好了
I. 安裝babel 全局後,無論是編譯還是命令都會彈出找不到babel-runtime/core-js/object/keys
擎宇(意思同上) 擊退了曹操的大軍擇日出征。張飛報仇心切志澤 (澤:廣域的水源 )
J. babel怎麼編譯箭頭函數
gulp 腳本中能不能使用箭頭函數取決於其運行環境,即 Node 的版本號。不過目前的版本應該都支持 ES6 語法。
gulp 本身不具備編譯 JS 的能力,肯定是通過第三方插件來編譯的,那麼要看你用的什麼插件以及什麼配置來編譯。
既然 webpack 直接可編譯,那麼使用 gulp 調用 webpack 來編譯就不應該出問題的。光從你提供的信息來看,目前也就只能這么回答了。