在Javascript類中使用setTimeout第1/2頁(yè)
更新時(shí)間:2008年01月22日 23:19:38 作者:
在Javascript類中使用setTimeout
最近遇到了一道 Javascript 考題,內(nèi)容如下:
嘗試實(shí)現(xiàn)注釋部分的 Javascript 代碼,可在其他任何地方添加更多
代碼(如不能實(shí)現(xiàn),說(shuō)明一下不能實(shí)現(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();坦白的說(shuō),之前我并沒(méi)有在 Javascript 類中使用 setTimeout/setInterval 的經(jīng)驗(yàn),所以開(kāi)始就很草率的認(rèn)為這是無(wú)法實(shí)現(xiàn)的。但是經(jīng)過(guò)深思熟慮以后發(fā)現(xiàn)是可以實(shí)現(xiàn)的。退一步說(shuō),隔五秒執(zhí)行某段語(yǔ)句是非常容易實(shí)現(xiàn)的。比如不考慮別的因素,題目中的函數(shù)是可以這樣寫:
this.waitAndShout = function(){
setTimeout('this.shout()', 5000);
}在運(yùn)行以后,誰(shuí)都會(huì)意識(shí)到 this 這個(gè)變量是無(wú)法找到的。但是這是為什么呢,很快就可以意識(shí)到,其實(shí) setTimeout/setInterval 是 window 對(duì)象的一個(gè)方法,所以也可以寫成 window.setTimeout/window.setInterval,那么上述的 this.shout() 就非??梢匀菀桌斫鉃槭裁床荒軋?zhí)行了,因?yàn)樗鼘?shí)際上調(diào)用的是 window.shout() 。
知道了原因以后解決起來(lái)就非常的容易了,只要將對(duì)象綁定到 window 對(duì)象下就可以(我對(duì) Javascript 有趣的對(duì)象機(jī)制感到興奮)。那么,上述的函數(shù)再做一個(gè)小的修改:
this.waitAndShout = function() {
window.Obj = this;
setTimeout('Obj.shout()', 5000);
}這樣就可以了。實(shí)際上
setTimeout('Obj.shout()', 5000);等價(jià)于
嘗試實(shí)現(xiàn)注釋部分的 Javascript 代碼,可在其他任何地方添加更多
代碼(如不能實(shí)現(xiàn),說(shuō)明一下不能實(shí)現(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();坦白的說(shuō),之前我并沒(méi)有在 Javascript 類中使用 setTimeout/setInterval 的經(jīng)驗(yàn),所以開(kāi)始就很草率的認(rèn)為這是無(wú)法實(shí)現(xiàn)的。但是經(jīng)過(guò)深思熟慮以后發(fā)現(xiàn)是可以實(shí)現(xiàn)的。退一步說(shuō),隔五秒執(zhí)行某段語(yǔ)句是非常容易實(shí)現(xiàn)的。比如不考慮別的因素,題目中的函數(shù)是可以這樣寫:
this.waitAndShout = function(){
setTimeout('this.shout()', 5000);
}在運(yùn)行以后,誰(shuí)都會(huì)意識(shí)到 this 這個(gè)變量是無(wú)法找到的。但是這是為什么呢,很快就可以意識(shí)到,其實(shí) setTimeout/setInterval 是 window 對(duì)象的一個(gè)方法,所以也可以寫成 window.setTimeout/window.setInterval,那么上述的 this.shout() 就非??梢匀菀桌斫鉃槭裁床荒軋?zhí)行了,因?yàn)樗鼘?shí)際上調(diào)用的是 window.shout() 。
知道了原因以后解決起來(lái)就非常的容易了,只要將對(duì)象綁定到 window 對(duì)象下就可以(我對(duì) Javascript 有趣的對(duì)象機(jī)制感到興奮)。那么,上述的函數(shù)再做一個(gè)小的修改:
this.waitAndShout = function() {
window.Obj = this;
setTimeout('Obj.shout()', 5000);
}這樣就可以了。實(shí)際上
setTimeout('Obj.shout()', 5000);等價(jià)于
您可能感興趣的文章:
- JavaScript window.setTimeout() 的詳細(xì)用法
- JavaScript setTimeout和setInterval的使用方法 說(shuō)明
- javascript setTimeout()傳遞函數(shù)參數(shù)(包括傳遞對(duì)象參數(shù))
- Javascript延遲執(zhí)行實(shí)現(xiàn)方法(setTimeout)
- Javascript對(duì)象中關(guān)于setTimeout和setInterval的this介紹
- javascript setTimeout和setInterval計(jì)時(shí)的區(qū)別詳解
- JavaScript SetInterval與setTimeout使用方法詳解
- Javascript的setTimeout()使用閉包特性時(shí)需要注意的問(wèn)題
- javascript中setTimeout使用指南
相關(guān)文章
JavaScript編程設(shè)計(jì)模式之構(gòu)造器模式實(shí)例分析
這篇文章主要介紹了JavaScript編程設(shè)計(jì)模式之構(gòu)造器模式,簡(jiǎn)單講述了構(gòu)造器模式的概念、原理,并結(jié)合實(shí)例形式分析了構(gòu)造器模式的定義與使用方法,需要的朋友可以參考下2017-10-10
javascript實(shí)現(xiàn)5秒倒計(jì)時(shí)并跳轉(zhuǎn)功能
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)5秒倒計(jì)時(shí)并跳轉(zhuǎn)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
JavaScript手寫數(shù)組的常用函數(shù)總結(jié)
這篇文章主要給大家介紹了關(guān)于JavaScript手寫數(shù)組常用函數(shù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
js遍歷json對(duì)象所有key及根據(jù)動(dòng)態(tài)key獲取值的方法(必看)
下面小編就為大家?guī)?lái)一篇js遍歷json對(duì)象所有key及根據(jù)動(dòng)態(tài)key獲取值的方法(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03
兼容低版本IE的JScript5.5實(shí)現(xiàn)
兼容低版本IE的JScript5.5實(shí)現(xiàn)...2006-09-09

