【问题标题】:JavaScript: Why isn't this callback function not working? [duplicate]JavaScript:为什么这个回调函数不起作用? [复制]
【发布时间】:2017-05-10 19:19:15
【问题描述】:

上面写着:TypeError: myFunc is not a function

我希望输出是“我很高兴,哈哈!”。

我正在学习 JS 中的回调函数。

function emotions(myString, myFunc) {
    console.log("I am " + myString + ", " + myFunc(2));
}
var laugh = function(val) {
    var ha="";
    for(var i=0;i<val; i++) {
        ha=ha+"ha";
    }
    return ha;
};

emotions("happy",laugh(2));

【问题讨论】:

  • 查看欺骗目标。 emotions = setTimeout, laugh = setTimeout 回调。
  • emotions('happy', laugh) 会工作的。有点儿。执行emotions("happy",laugh(2)) 本质上等于emotions("happy",'haha')。对于回调,您需要提供一个函数。所以在你的例子中你会做emotions("happy",function(){return laugh(2);})
  • JavaScript 的一个重要特性是将函数视为数据。在行业中,我们说职能是一等公民。这就是回调的工作方式:您将函数作为一条数据传递给另一个函数。在 JavaScript 中,有时您调用、执行、运行该函数,有时您只需分配它。如果你把一个功能想象成一个咖啡机,你有时想要咖啡,有时你想要机器本身。 继续……
  • ... 如果你想要函数(咖啡)的 result,你可以在名字后面加上括号来运行它:doit()。如果你想要函数本身(咖啡机),你可以在 没有 括号的情况下引用它。那是你的错误:laugh(2) 是函数的 result,而不是函数本身。如果你希望它是一个回调,它需要是laugh,不带括号。唯一的另一个问题是你不能简单地通过回调传递额外的参数,所以你不能简单地包含2
  • @Manngo 哇。非常感谢您精美地解释“回调”。

标签: javascript callback


【解决方案1】:

试试这个:

emotions("happy", laugh);

您遇到这个问题是因为您没有传递函数本身,但它是作为参数的结果。当您执行laugh() 时,您正在运行该函数,而不是使用它的引用,因此,您正在传递它的结果。

调用将在emotions函数内部执行为laugh(2),所以这是正确的方法。

function emotions(myString, myFunc) {
    console.log("I am " + myString + ", " + myFunc(2));
}
var laugh = function(val) {
    var ha="";
    for(var i=0;i<val; i++) {
        ha=ha+"ha";
    }
    return ha;
};

console.log(emotions("happy",laugh));

【讨论】:

  • 谢谢。你能告诉我为什么情绪(“快乐”,笑(2));没用?
  • @Abhayav 阅读更新。
  • 非常感谢。我现在明白了。
猜你喜欢
  • 1970-01-01
  • 2013-04-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-09-03
  • 2016-10-05
相关资源
最近更新 更多