在Javascript類中使用setTimeout第1/2頁
更新時間:2008年01月22日 23:19:38 作者:
在Javascript類中使用setTimeout
最近遇到了一道 Javascript 考題,內(nèi)容如下:
嘗試實現(xiàn)注釋部分的 Javascript 代碼,可在其他任何地方添加更多
代碼(如不能實現(xiàn),說明一下不能實現(xiàn)的原因):
var Obj = function(msg){
this.msg = msg;
this.shout = function(){
alert(this.msg);
}
this.waitAndShout = function(){
// 隔五秒鐘后執(zhí)行上面的 shout 方法
}
}
var testObj = new Obj("Hello,World!");
testObj.shout();坦白的說,之前我并沒有在 Javascript 類中使用 setTimeout/setInterval 的經(jīng)驗,所以開始就很草率的認為這是無法實現(xiàn)的。但是經(jīng)過深思熟慮以后發(fā)現(xiàn)是可以實現(xiàn)的。退一步說,隔五秒執(zhí)行某段語句是非常容易實現(xiàn)的。比如不考慮別的因素,題目中的函數(shù)是可以這樣寫:
this.waitAndShout = function(){
setTimeout('this.shout()', 5000);
}在運行以后,誰都會意識到 this 這個變量是無法找到的。但是這是為什么呢,很快就可以意識到,其實 setTimeout/setInterval 是 window 對象的一個方法,所以也可以寫成 window.setTimeout/window.setInterval,那么上述的 this.shout() 就非常可以容易理解為什么不能執(zhí)行了,因為它實際上調(diào)用的是 window.shout() 。
知道了原因以后解決起來就非常的容易了,只要將對象綁定到 window 對象下就可以(我對 Javascript 有趣的對象機制感到興奮)。那么,上述的函數(shù)再做一個小的修改:
this.waitAndShout = function() {
window.Obj = this;
setTimeout('Obj.shout()', 5000);
}這樣就可以了。實際上
setTimeout('Obj.shout()', 5000);等價于
嘗試實現(xiàn)注釋部分的 Javascript 代碼,可在其他任何地方添加更多
代碼(如不能實現(xiàn),說明一下不能實現(xiàn)的原因):
var Obj = function(msg){
this.msg = msg;
this.shout = function(){
alert(this.msg);
}
this.waitAndShout = function(){
// 隔五秒鐘后執(zhí)行上面的 shout 方法
}
}
var testObj = new Obj("Hello,World!");
testObj.shout();坦白的說,之前我并沒有在 Javascript 類中使用 setTimeout/setInterval 的經(jīng)驗,所以開始就很草率的認為這是無法實現(xiàn)的。但是經(jīng)過深思熟慮以后發(fā)現(xiàn)是可以實現(xiàn)的。退一步說,隔五秒執(zhí)行某段語句是非常容易實現(xiàn)的。比如不考慮別的因素,題目中的函數(shù)是可以這樣寫:
this.waitAndShout = function(){
setTimeout('this.shout()', 5000);
}在運行以后,誰都會意識到 this 這個變量是無法找到的。但是這是為什么呢,很快就可以意識到,其實 setTimeout/setInterval 是 window 對象的一個方法,所以也可以寫成 window.setTimeout/window.setInterval,那么上述的 this.shout() 就非常可以容易理解為什么不能執(zhí)行了,因為它實際上調(diào)用的是 window.shout() 。
知道了原因以后解決起來就非常的容易了,只要將對象綁定到 window 對象下就可以(我對 Javascript 有趣的對象機制感到興奮)。那么,上述的函數(shù)再做一個小的修改:
this.waitAndShout = function() {
window.Obj = this;
setTimeout('Obj.shout()', 5000);
}這樣就可以了。實際上
setTimeout('Obj.shout()', 5000);等價于
您可能感興趣的文章:
- JavaScript window.setTimeout() 的詳細用法
- JavaScript setTimeout和setInterval的使用方法 說明
- javascript setTimeout()傳遞函數(shù)參數(shù)(包括傳遞對象參數(shù))
- Javascript延遲執(zhí)行實現(xiàn)方法(setTimeout)
- Javascript對象中關(guān)于setTimeout和setInterval的this介紹
- javascript setTimeout和setInterval計時的區(qū)別詳解
- JavaScript SetInterval與setTimeout使用方法詳解
- Javascript的setTimeout()使用閉包特性時需要注意的問題
- javascript中setTimeout使用指南
相關(guān)文章
H5如何實現(xiàn)喚起APP及調(diào)試bug解決
這篇文章主要為大家介紹了H5如何實現(xiàn)喚起APP及調(diào)試bug解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05Javascript中eval函數(shù)的詳細用法與說明
Javascript中eval函數(shù)的詳細用法與說明...2007-03-03給事件響應函數(shù)傳參數(shù)的四種方式小結(jié)
這篇文章主要介紹了給事件響應函數(shù)傳參數(shù)的四種方式。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12