草庐IT

es6-features

全部标签

javascript - Jest : Mock ES6 Module with both default and named export

我有一个带有默认导出和命名导出的ES6模块:/**/src/dependency.js**/exportfunctionutilityFunction(){returnfalse;}exportdefaultfunctionmainFunction(){return'foo';}它被第二个ES6模块使用:/**/src/myModule.js**/importmainFunction,{utilityFunction}from'./dependency';//EDIT:Fixedsyntaxerrorincodesample//exportdefaultmyModule(){expor

javascript - ES6 为什么在循环中定义时可以重新分配常量

我正在尝试一些毫无意义的逻辑以更好地理解ES6,并且在定义常量时注意到了一个奇怪的现象。在循环中定义时,似乎可以更改常量赋值:"usestrict";for(consti=0;i这是预期的行为吗?任何人都可以阐明为什么会发生这种情况,循环中的声明是否不同?更新自Statements/constThisdeclarationcreatesaconstantthatcanbeglobalorlocaltothefunctioninwhichitisdeclared.Constantsareblock-scoped. 最佳答案 当您修改“

javascript - window.System 对象是 JavaScript ES6 的必需部分吗

不久前我读到Systemobject是es6模块的必需部分,基本上是一种新的对象类型,具有模块加载所需的所有语义。这是严格的es6要求吗?它似乎不在最新规范中。 最佳答案 全局System对象不是ES2015的一部分。包含System的模块加载API已从ES2015规范中删除Draft28,October2014.模块加载现在由单独的WhatWGloaderspec跟踪.在https://github.com/ModuleLoader/es6-module-loader的草案27(包括System)中指定了模块加载器API的实现。.

Javascript (ES6) 可迭代流

是否有使用ES6生成器使流可迭代的模式?请参阅下面的“MakeStreamIterable”。import{createReadStream}from'fs'letfileName='largeFile.txt'letreadStream=createReadStream(fileName,{encoding:'utf8',bufferSize:1024})letmyIterableAsyncStream=MakeStreamIterable(readStream)for(letdataofmyIterableAsyncStream){letstr=data.toString('utf

javascript - 您可以将 "dumb down"ES6 模板字符串转换为普通字符串吗?

我必须解决gettext识别ES6模板字符串的限制,并且我考虑将模板字符串的“非内插值”作为编译步骤,以便只有代码中的“正常”字符串。基本上我想实现的是改变这个constadjective='wonderful'constsomething=`Look,Iama${adjective}string`console.log(something)>"Look,Iamawonderfulstring"进入这个constadjective='wonderful'constsomething='Look,Iama${adjective}string'console.log(something)>

javascript - 浏览器将如何处理 ES6 导入/导出语法

我一直在思考这个问题很多天,我决定请教专家。浏览器将如何处理新的导入/导出语法?我的意思是:模块会被异步加载吗?仅引用我的主文件或入口文件,浏览器将延迟加载requiere模块。也许我对这个新架构遗漏或误解了什么?非常感谢!问候。 最佳答案 这是standardizednow并得到所有主要现代浏览器的支持。willthemodulesbeloadedasynchronously?是的,有两种选择;详情如下。Referencingonlymymainorentryfileandbrowserswilllazyloadtherequie

javascript - 选择如何更好地利用 ES6 const 并让

免责声明:我知道下面的问题可能会被视为“征求意见”(所以它会偏离主题)。但事实并非如此:我正在寻找优点和/或缺点事实,在考虑该问题时应将其考虑在内。一个偶然的机会,我刚刚读到(来自优秀的ExploringES6)关于constvsletvsvar的摘录,结论指出(粗体是我的):Thenwehavetwoapproaches:Preferconst:constmarksimmutablebindings.Preferlet:constmarksimmutablevalues.Ileanslightlyinfavorof#1,but#2isfine,too.令我困惑的是:这种偏好似乎是基于

javascript - ES6 值声明后如何判断它是否为 var/const/let?

这个问题在这里已经有了答案:HowtocheckthatES6"variable"isconstant?(4个答案)关闭3年前。我知道我可以通过查看它的声明位置来确定一个值是varconst还是let。但是我想知道-主要是为了调试、开发JS编译器和学术兴趣-是否有可能在创建变量(var/const/let-ness)后找出它的不变性/范围。即doThing(something)会回来let或等价物。就像我们可以使用typeof或something.constructor.name为构造函数确定类型。

javascript - 如何在全局范围内使用 ES6 模块而不是命名空间?

在ES6中定义一个类时,它会在全局范围内可用,您可以使用新的ES6括号封闭来防止这种情况发生:{classCar{constructor(make){this.make=make;this.currentSpeed=25;}getSpeed(){console.log(this.make+'isgoing'+this.currentSpeed+'mph.');}}window.MYNAMESPACE.Car=Car;}我有多个js文件,每个文件都有自己的类定义,我通过MYNAMESPACE在全局范围内使这些类可用。因此从任何地方创建一辆新车看起来像:varmyCar=newMYNAME

javascript - 使用 Gulp 导入 ES6 模块

我正在尝试将我的ES6模块导入到一个文件中,并运行Gulp来连接和缩小该文件。我遇到了ReferenceError:requireisnotdefinedatall.js(transpiled)lineno3。我已经使用gulp-babel转译了代码。我的js文件是:cart.js:classCart{constructor(){this.cart=[];this.items=items=[{id:1,name:'DoveSoap',price:39.99},{id:2,name:'AxeDeo',price:99.99}];}getItems(){returnthis.items;}