jjzjj

bad_function_call

全部标签

javascript - JS : What do the curly braces inside function parameter declarations mean?

这个问题在这里已经有了答案:Whatdocurlybracesinsideoffunctionparameterlistsdoines6?(3个答案)关闭4年前。我一直在关注thistutorial在使用Redux设置React时,我注意到一些我不熟悉的语法。函数参数定义里面的花括号是干什么的?例子:functionStream({tracks=[],onAuth}){#whatisgoingonhere?return(...#componentstuffhere);}这是React特有的吗?还是这与Babel或其他图书馆有关?我是这项技术的新手,所以不确定发生了什么。

javascript - Array.prototype.slice.call(arguments) 与 Array.prototype.slice.apply(arguments)

上一个posts已经讨论过Array.prototype.slice.call(arguments)是如何工作的,但我不明白你为什么使用call而不是apply当apply用于类似数组的对象时,而call用于以逗号分隔的对象列表。arguments不是应该使用apply而不是call的类数组对象吗? 最佳答案 如果您想将参数传递给数组中的slice而不是一个一个地传递,那就有区别了。你可以这样做[1,2,3,4,5,6,7]----ourexampleargumentsArray.prototype.slice.call(argum

javascript - JS : is it possible to define getter functions on array members?

我还没有找到关于这个主题的任何信息,如果这是一个非常奇怪的问题,请原谅我。我知道JS允许将属性定义为访问器,这意味着它们在使用时会触发getter或setter函数。我的问题是是否可以对数组成员执行相同的操作。例如,我希望在这样分配时触发一个setter函数:myObj[2]=2/*setfunction(value,index){console.log(value+index)}*/如果这不可能,是否有任何其他方法可以扩展[]操作? 最佳答案 基本上,除非您对数组进行子类化,否则您不能。即使是子类化,数组也比对象动态得多。与对象不

javascript - Function() 构造函数是否没有像 eval 那样被 V8 优化?

我们正在尝试一种通过WebSockets接收网络组件的方法。这些组件包含自定义脚本,它们应该在组件内的上下文中运行。简而言之,我们有一些脚本字符串并想要运行它们。现在我们为此使用eval,像这样:functionctxEval(ctx,__script){eval(__script);//returnthingswiththectx}并按预期工作,但我读到任何包含eval的函数都没有被V8优化。我想像这样将它转换为newFunction():newFunction("ctx",__script)(ctx);这样我可以实现与上面的ctxEval函数相同的效果。我们知道Function是e

javascript - 使用 forEach、[].forEach.call(...) 或 Array.prototype.slice.call(...).forEach 迭代类似数组的对象?

我们可以使用以下两种方法实现类数组对象的迭代:letarrayLike=document.getElementsByClassName('dummy');[].forEach.call(arrayLike,(e)=>{console.log(e);});Test1Test2或者先使用slice将类数组对象转换为数组:letarrayLike=document.getElementsByClassName('dummy');Array.prototype.slice.call(arrayLike).forEach((e)=>{console.log(e);});Test1Test2哪个更

javascript - 为什么 function.apply() 不能在 IE 中跨文档边界工作?

我在IE中看到一些奇怪的行为,试图通过function.apply()调用另一个页面中的函数。这是一个简单的测试用例:test1.html:varopened=null;functionapplyNone(){opened.testFunc.apply(opened);}functionapplyArgs(){opened.testFunc.apply(opened,["appliedarray"]);}functioncall(){opened.testFunc("calleddirectly");}functionremoteApply(){opened.testApply(["u

javascript - Javascript 的 Function.toString() 的逆运算

对于Javascript应用程序,我需要能够让用户保存对象的状态。这涉及保存一组以前动态创建或通过GUI创建的自定义函数,并在以后加载这些存储的函数。本质上,我需要序列化和反序列化函数。现在我通过使用Function对象的.toString()方法实现序列化部分:func.toString().replace('"','\"').replace(/(\r)/g,'').replace(/(\n)/g,'').replace(/(\t)/g,'')这给了我这样美丽的“序列化”函数(注意该函数未命名):"function(someParameter){this.someFunctionNa

javascript - 语法错误 : invalid arrow-function arguments (parentheses around the arrow-function may help)

这样的代码会产生一个错误:if(hr>t1[0]||(hr==t1[0]&&min=>t1[1])&&hr错误:SyntaxError:无效的arrow-function参数(arrow-function周围的括号可能有帮助)这是什么意思,它是如何发生的?Google搜索此错误毫无用处。编辑:似乎是使用=>=而不是=引起的。但我仍然很好奇为什么错误是这样表述的,以及箭头函数应该是什么。编辑2.首先,我没有意识到这实际上可能是特定于浏览器的问题。另外,我没有意识到现在人们在浏览器上下文之外的其他地方使用JS。所以,为了说明这一点,我的浏览器是MozillaFirefox25.0.1。

javascript - 错误 : Zeptojs Animate Is Not A Function

zeptojs文档here当我使用$().animate函数时抛出如下错误:TypeError:$(...).animate不是函数而我使用的版本是页面提供的。 最佳答案 $(...).animate在zeptofx模块中。它不再在zepto的基本主要发行版中!http://zeptojs.com/#modules 关于javascript-错误:ZeptojsAnimateIsNotAFunction,我们在StackOverflow上找到一个类似的问题:

javascript - "bar"中 "var foo = function bar (){ ... }"的用途是什么?

在DouglasCrockford的书中,他将递归函数写为:varwalk_the_DOM=functionwalk(node,func){func(node);node=node.firstChild;while(node){walk(node,func);node=node.nextSibling;}}我从未见过定义为varfoo=functionbar(){...}的函数-我总是看到声明的右侧是匿名的:varfoo=function(){...}声明右侧的名称walk的唯一目的是缩短walk_the_DOM的调用吗?它们似乎成为相同功能的不同名称。也许我误解了这段代码的工作原理。