jjzjj

es6-modules

全部标签

javascript - ES6 : import many files

我有一个导入大量AMD模块并在每个模块上调用初始化方法的脚本:define(['underscore','./mod0',...,'./modN'],function(_){_.each(_.toArray(arguments).slice(1),function(m){init(m);});});我需要切换到ES6导入语法,我想弄清楚是否可以从列表中导入模块,其方式类似于我的AMD代码。我想避免像这样的精神错乱:importmod0from'./mod0';...importmodNfrom'./modN';init(mod0);...init(modN);关于如何实现这一点有什么建

javascript - 在 ES6 中什么是新规范, "block-level function declaration"是什么意思?

我正在尝试学习es6兼容性表Here.在bindings部分它说“block级函数声明?”。除了官方spec,我找不到任何博客或文档在那个词的组合上。问题:“block级函数声明”指的是什么? 最佳答案 示例kangax正在测试:alert(function(){'usestrict';functionf(){return1;}{functionf(){return2;}}returnf()===1;}());这意味着函数“提升”的行为方式与let相同(与var相比)。在ES5中,大括号是“装饰”,除非出现在for、if、try等几

javascript - 使用 `module` 作为命名空间

我一直在我的node.js模块中使用一种模式,这种模式对我来说非常明显,以至于我认为它一定有问题,否则我会看到更多人这样做。为了保留模块全局的私有(private)变量,我只是将它们作为属性附加到模块对象上。像这样:module.exports={init:function(){module.someClient=initializeSomethingHere()},someMethod:function(done){module.someClient.doSomething(done)}}这对我来说似乎比这样的东西更可取......varsomeClient;module.expor

javascript - 减少用于生产的 node_modules 的大小

我们的部署过程需要很长时间,部分原因是将node_modules文件夹传递到生产服务器。我的Package.json看起来像这样:{"name":"coms-sass","version":"0.0.1","description":"SassgulptaskforCOMSServicePortal","main":"gulpfile.js","dependencies":{"angular":"^1.5.5","angular-sanitize":"=1.5.5","angular-ui-bootstrap":"^1.3.2","gridster":"^0.5.6","gulp":"

javascript - ES6 命名空间导入 : behavior of "this"

从命名空间导入调用的导入函数中,this的值是多少?(根据ECMA规范)//module.jsexportfunctionfun(){returnthis;}//main.jsimport*asmodulefrom"./module.js";letx=module.fun();//What'sthevalueofxhere?我的猜测是:它是module对象,但在规范中还没有找到明确的答案。正常行为是否适用于此,或者在ES6模块中是否有一些特殊的namespace导入? 最佳答案 没有,这里没有特殊行为。Modulenamespace

javascript - 导入值与其导出值断开连接是否仍然是只读的?

给定以下模块结构://moduleA:exportleta=1;//namedexportexportfunctioninc(){a++;}//namedexport//moduleB:letb=1;exportdefaultb;//defaultexport(equivalentto`exportdefault1`)exportfunctioninc(){b++;}//namedexport//moduleC:letc={};exportdefaultc;//defaultexport//moduleE:importa,{incasincA}from"./A";importb,{in

javascript - 未捕获的 TypeError : (0 , _store.configureStore) 不是函数

这个问题在这里已经有了答案:WhenshouldIusecurlybracesforES6import?(11个答案)关闭6年前。商店.jsimport{createStore,applyMiddleware}from'redux';importcreateLoggerfrom'redux-logger';importrootReducerfrom'./reducers/index';constlogger=createLogger();constcreateStoreWithMiddleware=applyMiddleware(logger)(createStore);exportd

javascript - 为什么我们需要将 module.exports 作为参数传递,因为我们已经将 module 作为参数传递了?

我一直在阅读一些关于Node.js的在线教程。我的理解是,在使用require(./file-path)函数时,Node获取该文件的内容并包装在一个立即调用的函数中(function(exports,require,module,__filename,__dirname){//content}())我了解exports和module.exports之间的区别。这就是我在互联网上搜索上述问题时所能看到的全部内容。但我的问题是,为什么我们需要将module.exports和module传递给包装IIFE?我们可以单独传递模块,然后从中获取module.exports。这样做有什么好处吗?通

javascript - 使用对象扩展运算符添加多个对象(ES6、JavaScript)

我有3个具有相同数据但内部数组具有单独服务和提供ID的对象,因此我尝试获得如下所述的预期结果和pleasecheckmytryhere.提前致谢对象1:constobj1={bid:1,mobile:9533703390,services:[{service_id:5,offer_id:10,count:1}]}对象2:constobj2={bid:1,mobile:9524703390,services:[{service_id:8,offer_id:12,count:1}]}对象3:constobj3={bid:1,mobile:9524703390,services:[{serv

javascript - 如何使用 ES6 传播更新多个对象子字段?

我们有react-graph-vis状态的选项:{options:{physics:{enabled:false...}}nodes:{font:“12pxsans-serif#888f99”...}}我们想用父组件的属性更新options.physics.enabled和options.nodes.font而不删除或编辑状态中的任何其他默认选项:我是不是理解错了? 最佳答案 你的第一次传播很棒,你只需要为children​​传播对象。您是正确的,因为您正在删除physics和nodes中的所有其他字段。试试这个^^。