Undefined不是一个函数- JavaScript
Undefined is not a function - JavaScript
我有一个简单的问题。下面是
的代码 var num = 0;
var increment = function() {
return function() { num++; };
};
increment();
increment();
然而,当我试图运行它时,它与undefined is not a function
错误。怎么会?难道increment
不是一个函数吗?
同样,当我写typeof increment
时,它返回undefined
。
当increment()
被调用两次时,它应该修改num
,变成2。
我猜你想做这样的事情:
> var makeIncrement = function () { var num = 0; return function () { return num++ } }
undefined
> increment = makeIncrement()
function () { return num++ }
> increment()
0
> increment()
1
必须调用函数(makeIncrement()
)才能返回内部函数,然后可以将其赋值给变量。一旦它被分配,你就可以调用它,它将按照你的期望工作。
var num = 0;
var increment = function() {
num++;
};
increment();
increment();
但是你用return function()返回什么?你应该只返回num。
var num = 0;
var increment = function() {
num++
return num;
};
var something = 0;
something = increment();
something = increment();
alert(something);
根据你的评论,如果你想从你的函数返回一个函数,调用increment()
返回的函数:
var num = 0;
var increment = function() {
return function() { num++; };
};
increment()();
increment()();
或者,更合适:
var incrementer = increment();
incrementer(); //Call this each time you want to increment num
这不是一个函数…完全正确。你的函数"increment"返回一个函数,而不是增加的值。正确的做法应该是:Var increment = function(){返回num++;
};菲尔是的,增量函数不增加变量;它返回一个内部函数,该函数在调用时将变量自增。
如前所述,必须调用调用增量函数的结果:increment()(); //results in num++
或
var incrementFunction = increment(); //does not increment
incrementFunction(); //num++
如果您想将内部函数分配给increment
,那么您需要执行外部函数:
var increment = (function() {
return function() { num++; };
}());
(这被称为立即调用的函数表达式,简称IIFE)。当然,更简单的方法是:
var increment = function() { num++; };
但是也许你有其他的原因想要用更复杂的方式来做
相关文章:
- 我可以在json对象中添加一个函数吗
- 如何在JQuery函数中定义一个值,然后调用另一个函数并使用该值
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在另一个函数中使用变量this
- 在另一个函数成功结束后调用该函数
- mongoose.connect undefined不是一个函数
- 监听器必须是一个函数
- 使用JS函数来使用另一个函数的语法?node.js
- 如何取消object.prototypes javascript的一个函数
- 从Chrome扩展名中的popup.html文件在background.js文件中运行一个函数
- 嵌套到另一个函数中的Fancybox函数;不起作用
- 如何在javascript中使用不止一个函数
- jQuery-在页面加载时执行一个函数
- jquery UI draggable:UI.children不是一个函数
- jQuery Mobile Undefined不是一个函数
- 如何在php中创建一个函数,该函数与文本区域一起工作,通过输入类似[color:red]的内容来打印具有等效颜色的文本
- javascript函数将数据添加到屏幕,但随后被另一个函数覆盖
- JS异常:animate不是一个函数
- 如何将一个函数附加到一个不存在的元素上
- JavaScript/jQuery-添加添加和删除类与下一个函数之间的延迟