我有下一个代码:
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”方法检查是否存在指示内容的元素。但是......它推动了元素......我不知道发生了什么......
我使用按钮创建了事件:如果我在此处多次单击,则复制元素...
答案 0 :(得分:4)
我解决了这个问题如下:
function indexOf(array, item) {
for (var i = 0; i < array.length; i++) {
if (array[i].toString() === item.toString()) return i;
}
return -1;
}
此方法适用于我的代码。