欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在window.setTimeout方法中傳送對象

 更新時間:2006年12月22日 00:00:00   作者:  
setTimeout方法是js中的延時方法,很多js的bug,只需要使用該方法延時一下,就會自動解決了,簡直就是萬能藥方,也是我比較喜歡使用的最后手段。
其語法是:

window.setTimeout(expr,msec)

    expr是執(zhí)行字符串,在msec毫秒之后,就會作為js運行。我昨天才發(fā)現(xiàn),原來expr也可以是一個函數(shù),呵呵,用這個特性,就可以進行對象的傳送了。
    下面的代碼實現(xiàn)了把函數(shù)foo1中的對象p,延時傳送到函數(shù)foo2中的功能。 




現(xiàn)在很多框架其實都直接一種多投事件(它的實現(xiàn)原理也不復雜),一個多投事件本身,其實是是一個標準的函數(shù),但是它一般有下述的方法。

MuEvent.add = function (func) { ... }

MuEvent.addMethod = function (instance, func) { ... }

 

當使用第一種方法時,在激活func這個事件處理函數(shù)時,使用MuEvent的當前實例為this對象;第二種則使用傳入的instance作為this對象。

 

因此對于setTimeout來說,我們傳統(tǒng)的方法要這樣使用它來激活方法:

----------
function doTimer() {
  obj1.call();
  obj2.call();
}
setTimeout(doTimer, 1000);


而使用多投事件的代碼就可以如下:

----------
var e = new MuEvent();
e.addMethod(obj1, obj1.call);
e.addMethod(obj2, obj2.call);

setTimeout(e, 1000);
----------

 

當然,你想要寫得COOL一點,可以是這樣:

----------

setTimeout(function() {

  return new MuEvent(obj1, obj1.call, obj2, obj2.call); 

}(), 1000);
----------  

作為一點點介紹,我所做的Qomo是用這種形式來實現(xiàn)的MuEvent。象Atlas之類的框架,大多也采用類似的方法。

相關文章

最新評論