在Javascript類中使用setTimeout
更新時(shí)間:2008年01月22日 23:19:38 作者:
在Javascript類中使用setTimeout
window.setTimeout('window.Obj.shout()', 5000);另外,之前我也想到將對象保存為數(shù)組,然后引用調(diào)用,代碼如下:
function ObjectClass (property) {
this.property = property;
this.id = ObjectClass.cnt;
ObjectClass.objects[ObjectClass.cnt++] = this;
this.method = ObjectClass_method;
}
ObjectClass.cnt = 0;
ObjectClass.objects = new Array();
function ObjectClass_method () {
setTimeout('ObjectClass.objects[' + this.id + '].method();', 5000);
}
var obj1 = new ObjectClass('feelinglucky');
obj1.method();不過個(gè)人感覺還是上述第一種方法清晰得多。
后記,Javascript 看來的確還是很多需要謹(jǐn)慎對待的地方,尤其是對象機(jī)制。就猶如我之前所說的,Javascript 并不比其他語言要復(fù)雜,但是它也沒有你想象中的簡單。
PS:完成這道題目以后, Google 發(fā)現(xiàn)其他的兄弟早已經(jīng)解決了此類的問題,比如這里還有這里,可以對比參考一下。
--------------------------------------------------------------------------------
更新,感謝 Sheneyan 兄弟的提醒,還有另外的一個(gè)辦法就是通過 Closure(閉包) 來實(shí)現(xiàn),代碼如下:
var Obj = function(msg){
this.msg = msg;
this.shout = function() {
alert(this.msg);
this.waitAndShout();
}
var _self = this;
this.waitAndShout = function() {
setTimeout(function(){_self.shout()}, 5000);
}
}
var testObj = new Obj("Hello,World!");
testObj.shout();看來這道題已經(jīng)不能再害人了 :^)
您可能感興趣的文章:
- JavaScript window.setTimeout() 的詳細(xì)用法
- JavaScript setTimeout和setInterval的使用方法 說明
- javascript setTimeout()傳遞函數(shù)參數(shù)(包括傳遞對象參數(shù))
- Javascript延遲執(zhí)行實(shí)現(xiàn)方法(setTimeout)
- Javascript對象中關(guān)于setTimeout和setInterval的this介紹
- javascript setTimeout和setInterval計(jì)時(shí)的區(qū)別詳解
- JavaScript SetInterval與setTimeout使用方法詳解
- Javascript的setTimeout()使用閉包特性時(shí)需要注意的問題
- javascript中setTimeout使用指南
相關(guān)文章
JavaScript編程設(shè)計(jì)模式之構(gòu)造器模式實(shí)例分析
這篇文章主要介紹了JavaScript編程設(shè)計(jì)模式之構(gòu)造器模式,簡單講述了構(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)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
js遍歷json對象所有key及根據(jù)動(dòng)態(tài)key獲取值的方法(必看)
下面小編就為大家?guī)硪黄猨s遍歷json對象所有key及根據(jù)動(dòng)態(tài)key獲取值的方法(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
兼容低版本IE的JScript5.5實(shí)現(xiàn)
兼容低版本IE的JScript5.5實(shí)現(xiàn)...2006-09-09

