Я работаю с виджетами jQuery ColorPicker, в частности реализуя функцию ColorPickerSetColor (только внутренняя настройка setColor). Выдержка из кода:Область действия функции jQuery each()?
setColor: function(col) {
if (typeof col == 'string') {
col = HexToHSB(col);
} else if (col.r != undefined && col.g != undefined && col.b != undefined) {
col = RGBToHSB(col);
} else if (col.h != undefined && col.s != undefined && col.b != undefined) {
col = fixHSB(col);
} else {
return this;
}
return this.each(function(){
if ($(this).data('colorpickerId')) {
var cal = $('#' + $(this).data('colorpickerId'));
cal.data('colorpicker').color = col;
cal.data('colorpicker').origColor = col;
fillRGBFields(col, cal.get(0));
fillHSBFields(col, cal.get(0));
fillHexFields(col, cal.get(0));
setHue(col, cal.get(0));
setSelector(col, cal.get(0));
setCurrentColor(col, cal.get(0));
setNewColor(col, cal.get(0));
}
});
}
Похоже, что в виджете есть ошибка. Параметр «col» при проверке внутри каждого вызова() не определен. Я прочитал документацию и другие примеры, и все, что я могу найти, указывает, что «col» все еще должен быть в области, когда каждый() вызов выполняет эту функцию, но, похоже, это не так ...
Помогите?
Спасибо!
Вы уверены, что col определен до возвращения this.each достигнуто? – seth
Да, я уверен. Если мы добавим команду console.log (протоколирование Firebug) прямо перед и сразу после возврата this.each, первая команда log() выводит допустимое значение, а вторая выводит undefined ... – rinogo