JavaScript 类型错误 : callback is not a function - how do i fix this?

标签 javascript object callback

我该如何解决这个问题?

问题是这样的:

实现一个函数“mapById”,当给定一个对象数组时,该函数返回一个对象,其中键是输入对象的 id,值是相应的输入对象。

例如:

mapById([{id: 102, name: "Alice"},
        {id: 205, name: "Bob", title: "Dr."},
        {id: 592, name: "Claire", age: 32}]);

返回:

{
102: {id: 102, name: "Alice"},
205: {id: 205, name: "Bob", title: "Dr."},
592: {id: 592, name: "Claire", age: 32}
}

var key = 回调(item); ^ 类型错误:回调不是函数

function mapById(list, callback) {
    var obj = {};
    list.forEach(function(item) {
        var key = callback(item);
        if (obj[key]) {
            obj[key] = obj[key].concat(item);
        } else {
            obj[key] = [item];
        }
    });
    return obj;
}

console.log(mapById(input));

最佳答案

问题:

您遇到的错误是,当您定义该函数时,您给了它两个参数:listcallback

function mapById(list, callback) {}

但是,当您调用该函数时,您只给了它一个参数:input

console.log(mapById(input));

因此,当您的代码执行并到达函数的这一部分时,它会抛出异常,因为回调是未定义的,因为您没有传递第二个参数。

解决方案:

很多方法可以解决您的问题。一种解决方案是在首次声明 mapById 时简单地在内部调用回调。

然后移动代码逻辑,当您CALLma​​pById时,NOT返回对象作为第二个参数当你声明它时。

例如

function mapById(list, callback) {
    var obj = {};
    return callback(item);
}

console.log(mapById(input, function() {
    // logic goes here
}));

请注意,我个人不会以这种方式构建它,因为回调是不必要的,但我将向您展示如何通过回调来完成它。

关于JavaScript 类型错误 : callback is not a function - how do i fix this?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48471749/

相关文章:

javascript - 将 jQuery 转换为 Mootools

Javascript 将 URL 转换为 ‘anchor’ 标签并将标签作为字符串存储在数组中

java - 将java对象列表转换为CSV

android - Activity和Fragment之间如何回调?

javascript - jQuery:使用 .stop(xxx, false) 调用 'complete' 回调

javascript - 如何停止 html 属性中 onclick 事件的事件传播?

javascript - jquery 显示基于获取第二个时钟的图像

javascript - 对象函数没有方法(我不是 javascript 编码器)

javascript - 为什么 javascript 函数每次调用都有实例?

java - 将菜单项添加到 Blackberry 菜单列表