// temp data
var array = [1,2,function() { }, 3, function() { }];
var cb = function() { console.log("foo"); }
var found = false;
console.log(_.map(array, function(val) {
if (_.isFunction(val) && !found) {
return found = true, _.compose(cb, val);
}
return val;
}));
Это перебирает массив и превращает первую найденную функцию в составную функцию.
Я ненавижу эту found = false
переменную / счетчик.Как мне от него избавиться?
Как алгоритм.
let found be 0
map value in array
if value satisfies condition and found is 0
let found be 1
return mutate(value)
else
return value
Обновление
Использование цикла for
for (var i = 0; i < array.length; i++) {
if (_.isFunction(array[i])) {
array[i] = _.compose(cb, array[i]);
break;
}
}
_.map
, _
, _.isFunction
, _.compose