IndexOf不能与包含数组的对象一起正常工作

时间:2014-12-08 10:06:20

标签: javascript arrays duplicates listener indexof

我有下一个代码:

function insertIfNotThere(array, item) {
    /* Push the new element everytime: because return -1 */
    if (array.indexOf(item) === -1) {
        array.push(item);
    }
    /*But this log shows 1, 2, 3 and so on...*/
    console.log(array.length);

}

function EventManager(target) {
    var target = target || window, events = {};
    this.observe = function(eventName, cb) {
        if (events[eventName]){
           /* This insert the new event everytime: indexOf doesn't work... */
           insertIfNotThere(events[eventName], cb);
        }else{
           events[eventName] = []; events[eventName].push(cb);
        }
        return target;
    };

    this.fire = function(eventName) {
        if (!events[eventName]) return false;
        for (var i = 0; i < events[eventName].length; i++) {
        events[eventName][i].apply(target, Array.prototype.slice.call(arguments, 1));
        }
    };
}

我使用“insertIfNotThere”方法检查是否存在指示内容的元素。但是......它推动了元素......我不知道发生了什么......

我使用按钮创建了事件:如果我在此处多次单击,则复制元素...

1 个答案:

答案 0 :(得分:4)

我解决了这个问题如下:

function indexOf(array, item) {
    for (var i = 0; i < array.length; i++) {
        if (array[i].toString() === item.toString()) return i;
    }
    return -1;
}

此方法适用于我的代码。