Я заметил, что при нескольких попытках получить количество выпавших элементов он всегда возвращает меньше, чем найденное число, но если я попытаюсь выполнить ту же команду через консоль Chromes, я получаю ответ propper.
Я предполагаю, что DOM не обновляется, когда этот скрипт работает, поэтому я бросил механизм тайм-аута/повторить попытку, но все же безрезультатно. Что мне не хватает?
Ожидаемый размер результата= 10
Фактический размер результата= 9
Код
var asmCount = 0;
function storeValues(values, tryNumber){
var size = values.length,
tryNumber = (!isNaN(tryNumber)) ? tryNumber : 1
;
console.log('full boat:' + size + ', try #'+ tryNumber + ' ' + typeof(tryNumber));
if(tryNumber > 60){
console.log('too many tries');
return;
}
if(size < 10){
console.log('missing entries');
tryNumber = tryNumber + 1;
setTimeout(storeValues($('.asm-ranking .receiver .asm-value'), tryNumber) , 500);
} else if(size > 10){
console.log('too many entries, something broke');
} else {
console.log('just right, lets do this shit.');
//$.each(values, function(k,v){ console.log($(v).data('id'));});
}
}
$('.asm-ranking .receiver').droppable({
drop: function(event,ui){
var _self = this,
receiverCount = $('.asm-ranking .receiver li').length
;
//console.log('event',event);
//console.log('ui', ui);
asmCount++;
console.log(asmCount + ' / ' + receiverCount);
if(receiverCount == asmCount){
storeValues($('.asm-ranking .receiver .asm-value'), 1); // give DOM time to catch up, then store
}
}
});
по какой-то причине, когда я завернул свою ноту jQuery в готовый документ
$(document).ready(function{ ... })
он работает так, как ожидалось.