jQuery 1.5 yeni Ertelenmiş nesne ve ekli yöntemleri getirir .when
, .Deferred
ve ._Deferred
.
Daha .Deferred
önce kullanmayanlar için bunun kaynağına açıklama ekledim .
Bu yeni yöntemlerin olası kullanımları nelerdir, bunları kalıplara uydurmaya nasıl gidebiliriz?
API ve kaynağı zaten okudum , bu yüzden ne yaptığını biliyorum. Sorum şu: Bu yeni özellikleri günlük kodda nasıl kullanabiliriz?
AJAX isteği sırayla çağıran bir arabellek sınıfı basit bir örneği var . (Bir öncekinin bitmesinden sonra bir sonraki başlangıç).
/* Class: Buffer
* methods: append
*
* Constructor: takes a function which will be the task handler to be called
*
* .append appends a task to the buffer. Buffer will only call a task when the
* previous task has finished
*/
var Buffer = function(handler) {
var tasks = [];
// empty resolved deferred object
var deferred = $.when();
// handle the next object
function handleNextTask() {
// if the current deferred task has resolved and there are more tasks
if (deferred.isResolved() && tasks.length > 0) {
// grab a task
var task = tasks.shift();
// set the deferred to be deferred returned from the handler
deferred = handler(task);
// if its not a deferred object then set it to be an empty deferred object
if (!(deferred && deferred.promise)) {
deferred = $.when();
}
// if we have tasks left then handle the next one when the current one
// is done.
if (tasks.length > 0) {
deferred.done(handleNextTask);
}
}
}
// appends a task.
this.append = function(task) {
// add to the array
tasks.push(task);
// handle the next task
handleNextTask();
};
};
Ben gösteriler ve olası kullanımlar için arıyorum .Deferred
ve .when
.
Örneklerini görmek de güzel olurdu ._Deferred
.
jQuery.ajax
Örnekler için yeni kaynağa bağlanmak hile yapmaktır.
Bir işlemin eşzamanlı veya eşzamansız olarak yapılıp yapılmadığını özetlediğimizde özellikle hangi tekniklerin mevcut olduğu ile ilgileniyorum.
._Deferred
basitçe kullanılan "Ertelenmiş nesne" dir .Deferred
. Bu, muhtemelen hiç ihtiyacınız olmayacak bir iç nesnedir.