Это должно было обеспечить более надежную проверку итерационных объектов и уменьшить структуру управления.Можно ли удалить здесь null для удаления?
Я принял приведенный ниже код и изменил его, чтобы избавиться от первоначальной проверки для null. Явным образом проверяя что-то с помощью ключей, мы можем обеспечить, казалось бы, более сильную гарантию того, что что-то не будет проскальзывать (obj == null), и мы можем исключить 1 из 4 управляющих операторов. Обновление находится в фрагменте 2.
Кроме того, добавив в чек на && obj
, мы можем избежать ошибок, возникающих, что, по-видимому, было для первоначальной проверки.
obj == null
обнаружит undefined
и null
.
От Underscore:
Snippet1
var each = _.each = _.forEach = function(obj, iterator, context) {
if (obj == null) return;
if (nativeForEach && obj.forEach === nativeForEach) {
obj.forEach(iterator, context);
} else if (obj.length === +obj.length) {
for (var i = 0, l = obj.length; i < l; i++) {
if (iterator.call(context, obj[i], i, obj) === breaker) return;
}
} else {
for (var key in obj) {
if (_.has(obj, key)) {
if (iterator.call(context, obj[key], key, obj) === breaker) return;
}
}
}
};
Новый сниппет. Строка непосредственно после комментария была изменена.
Отрывок 2a
var each = _.each = _.forEach = function(obj, iterator, context) {
// modify - obj &&
if (nativeForEach && obj && obj.forEach === nativeForEach) {
obj.forEach(iterator, context);
// modify - obj &&
} else if (obj && (obj.length === +obj.length)) {
for (var i = 0, l = obj.length; i < l; i++) {
if (iterator.call(context, obj[i], i, obj) === breaker) return;
}
} else {
for (var key in obj) {
if (_.has(obj, key)) {
if (iterator.call(context, obj[key], key, obj) === breaker) return;
}
}
}
};
Если 0 из 3-х случаях совпадают, он провалится и return undefined
по умолчанию, то есть, в неявном виде.
Будет ли это правильно работать?
Per обсуждения:
Snippet 2b
var each = _.each = _.forEach = function(obj, iterator, context) {
if (obj && (obj.length === +obj.length)) {
for (var i = 0, l = obj.length; i < l; i++) {
if (iterator.call(context, obj[i], i, obj) === breaker) return;
}
} else {
for (var key in obj) {
if (_.has(obj, key)) {
if (iterator.call(context, obj[key], key, obj) === breaker) return;
}
}
}
};
В чем проблема с первым фрагментом? Использование защитных условий - хорошая практика. –
Что вы подразумеваете под «* Явным образом проверяю что-то с ключами»? – Bergi