草庐IT

ES导入导出

全部标签

javascript - Firefox ES6,获取类构造函数名称

在Firefox中使用ES6类时,我在获取构造函数的名称时遇到问题。在Chromium中它工作正常,但Firefox似乎有某种错误?在Firefox中,我只返回一个空字符串。有人知道解决方法吗?classMyClass{}leta=newMyClass();console.log(a.constructor.name); 最佳答案 我认为这是一个错误(根据下面的评论)。似乎指定显式构造函数在Firefox中表现出正确的行为(即使是最新版本48)。classMyClassWithConstructor{constructor(){co

javascript - 意外的 token 导出 webpack

我有这样的webpack配置:loaders:[{test:/\.js$/,exclude:/node_modules/,loader:'babel-loader'}]和babel配置:{"presets":['es2015'],"plugins":['transform-runtime']}但是浏览器显示这个消息:UncaughtSyntaxError:Unexpectedtokenexport怎么了? 最佳答案 如果你使用的是webpack2loaders成为rules 关于java

javascript - es5 中 ES6 方法(类)的等价物是什么?

我们如何将es6类方法填充到ES5中?我正在看一本书,上面写着以下内容:classNinja{constructor(name){this.name=name;}swingSword(){returntrue;}}与相同functionNinja(name){this.name=name;}Ninja.prototype.swingSword=function(){returntrue;};我只是问为什么我们要在原型(prototype)上而不是在构造函数中添加swingSword?因为函数应该在对象上,而不是在原型(prototype)链上。我是对还是错?

javascript - 在 ES Lint 中为 React Native 应用程序将 WebSocket 定义为全局变量

我收到以下eslint错误:42:21error'WebSocket'isnotdefinedno-undef您不能从react-native导入WebSocket,因为它是全局的,但是当我将WebSocket作为全局变量添加到我的.eslintrc.yml时,它不会改变结果错误:globals:WebSocket:true如何在ESLint中为ReactNative应用将WebSocket定义为全局?这可以修复吗?目前我的.eslintrc看起来像这样:env:browser:falsees6:truecommonjs:truenode:trueextends:'airbnb'par

javascript - 等效于 ES6 Promises 的 BlueBird Promise.props?

我想等待Promise的单词映射完成。BlueBird有Promise.props可以实现这一点,但是有没有一种干净的方法可以在常规javascript中做到这一点?我想我可以创建一个包含单词和Promise的新对象,获取这些对象的Promise数组,然后调用Promise.all并将它们放入map中,但这似乎有点矫枉过正。 最佳答案 适用于普通对象的Bluebird.props实现:/***Thisfunctionmaps`{a:somePromise}`toapromisethat*resolveswith`{a:resolve

javascript - 是否可以在 Mocha 测试中使用 ES6 模块?

ES6、Windows10x64、Node.js8.6.0、Mocha3.5.3是否可以在Mocha测试中使用ES6模块?我遇到了export和import关键字的问题。/*eventEmitter.js*//*Eventemitter.*/exportdefaultclassEventEmitter{constructor(){constsubscriptions=newMap();Object.defineProperty(this,'subscriptions',{enumerable:false,configurable:false,get:function(){returns

javascript - Q :ES6 map. keys() after map.delete(key)

当我尝试这些代码时:constmap=newMap([['a',1],['b',2],['c',3],['d',4],['e',5]]);console.log(map.keys());map.delete('a')console.log(map.keys());chrome控制台将显示这些:MapIterator{"a","b","c","d","e"}MapIterator{"c","d","e"}“b”为什么不出现? 最佳答案 这是一个浏览器兼容性问题,发生在map.keys()、map.values()、map.entrie

每隔 x 分钟导入一个本地 JSON 文件的 JavaScript 方法

我是JavaScript的新手,我一直在寻找解决这个问题的方法:我将姓名和号码写入data.json文件,该文件与我的JavaScript文件位于同一目录中。我正在寻找的是每隔几分钟检查data.json并使用更改更新我的HTMLp标记。我的HTMLblock如下所示:......我的data.json看起来像这样:[{"Name":"Charlie","Number":"5"},{"Name":"Patrick","Number":"3"}]我的Javascriptblock看起来像这样:...setInterval(function(){varjson=//readinjsonfi

javascript - 动态导入vue组件解析失败

当我尝试使用import()函数导入动态组件时,我收到以下错误:[Vuewarn]:Failedtoresolveasynccomponent:function(){return__webpack_require__("./src/components/typeslazyrecursive^\\.\\/field\\-.*$")("./field-"+_this.type);}Reason:Error:Loadingchunk0failed.不幸的是,我不知道是什么导致了这个错误。由于ReleaseNotes,我已经尝试在vue-loader配置中将esModule设置为false.我

javascript - 为什么在 ES2015 中将 Object.keys 更改为将原语强制转换为对象?

有谁知道从将基元传递给Object.keys时抛出错误到默默地将基元强制转换为对象并返回结果的变化背后的原因?我不确定是否有人会期望Object.keys('abc')返回[0,1,2],这似乎违反了“不要破坏网络”的首要指令。如果某些网站的代码将对Object.keys的调用包装在try/catch中以处理调用者错误地传递原语怎么办?这就是为什么我觉得改变背后必须有一个强有力的理由。如果有人知道这方面的信息,我将非常感兴趣。 最佳答案 我在esdiscuss上找不到关于这个决定的任何提及,所以我只能提供我自己的观点。正如一位评论者