在线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 来编译就不应该出问题的。光从你提供的信息来看,目前也就只能这么回答了。