DOJO的Deferred机制

(AJAX)程序的一系列异步调用过程中,由于回调发生时间的不确定性,会面临回调函数触发管理的问题。Twisted中有一个Deferred机制用来解决这个问题,这个机制同样也被DOJO框架所引入。

 

Deferred其实是一个对象,通常这个Deferred对象持有一系列的callBack和errBack函数组成。

 

以AJAX call为例,通过方法request向server发出请求,收到server的回调后,由callBack函数处理回调;如果回调出错则由errBack处理。

 

 

一般流程

 

一个典型的使用Deferred机制方法是在request方法发出请求(1)后立刻返回一个Deferred对象(2),这个对象持有Callback和Errback函数的引用(3)。当server的回调到达时,通过某种机制(例如匹配id,通常依据具体应用而设计)找到该Deferred对象,执行其中的Callback和Errback函数。

 

 

 

其实Deferred可以持有一组链式的Callback和Errback函数组,可以让回调处理按照链式顺序进行:

 


 

DOJO的实现

dojo.Deferred其实代码并不复杂,通过addBoth,addCallback,addErrback实现回调函数的注册,需要注意的是callback和errback总是成对被注册的,也就是说如果用addCallback单独添加一个Callback函数的话,那么默认的Errback就是null。这些“回调函数对”被添加到一个Array(chain)中,等到callback或者errback被触发时被按顺序调用。

 

dojo.Deferred还设计了嵌套Deferred对象调用,也就是在某一Callback函数下存在另一个Deferred对象,这第二个Deferred对象的执行依赖于第一个Deferred对象的执行。实际上,这使事情变得复杂了,如果没有处理好第二个Deferred(比如执行其中的Callback出错),会使第一个Deferred中的剩下的Callback不能被执行到(因为有时候Errback会是null),从而产生意想不到的bug。可以参考一个bug的例子

 

不仅仅在AJAX call可以使用Deferred,在任何需要异步处理的地方都可以使用这个机制,比如DOJO中有非常多的例子可以查看。由于采用了对象的概念,Deferred使管理复杂的异步回调的过程变得简单,也使程序结构变得清晰。

你可能感兴趣的:(Ajax,框架,dojo)