嘗試實現注釋部分的 Javascript 代碼,可在其他任何地方添加更多 代碼(如不能實現,說明一下不能實現的原因):

var Obj = function(msg){ this.msg = msg; this.shout = f " /> 麻豆视频一区二区三区,a在线观看免费视频,天天摸夜添狠狠添高

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

在Javascript類中使用setTimeout第1/2頁

最近遇到了一道 Javascript 考題,內容如下:

嘗試實現注釋部分的 Javascript 代碼,可在其他任何地方添加更多
代碼(如不能實現,說明一下不能實現的原因):

var Obj = function(msg){
   this.msg = msg;
   this.shout = function(){
      alert(this.msg);
   } 

   this.waitAndShout = function(){
      // 隔五秒鐘后執行上面的 shout 方法
   }
}

var testObj = new Obj("Hello,World!");
testObj.shout();坦白的說,之前我并沒有在 Javascript 類中使用 setTimeout/setInterval 的經驗,所以開始就很草率的認為這是無法實現的。但是經過深思熟慮以后發現是可以實現的。退一步說,隔五秒執行某段語句是非常容易實現的。比如不考慮別的因素,題目中的函數是可以這樣寫:

this.waitAndShout = function(){
    setTimeout('this.shout()', 5000);
}在運行以后,誰都會意識到 this 這個變量是無法找到的。但是這是為什么呢,很快就可以意識到,其實 setTimeout/setInterval 是 window 對象的一個方法,所以也可以寫成 window.setTimeout/window.setInterval,那么上述的 this.shout() 就非常可以容易理解為什么不能執行了,因為它實際上調用的是 window.shout() 。

知道了原因以后解決起來就非常的容易了,只要將對象綁定到 window 對象下就可以(我對 Javascript 有趣的對象機制感到興奮)。那么,上述的函數再做一個小的修改:

this.waitAndShout = function() {
    window.Obj = this;
    setTimeout('Obj.shout()', 5000);
}這樣就可以了。實際上

setTimeout('Obj.shout()', 5000);等價于

JavaScript技術在Javascript類中使用setTimeout第1/2頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 免费人成综合在线视频 | 国产剧情自拍 | 黄色网址在线视频 | 亚洲爱婷婷色婷婷五月 | 精品在线免费观看视频 | 国产精品白浆在线播放 | 色交视频 | a亚洲va韩国va欧美va久久 | 美女扒开腿让男人捅爽 | 欧美性开放视频 | 国产资源在线视频 | 精品久久一| 成人亲子乱子伦视频 | 国产欧美亚洲精品综合在线 | 日本一二三高清 | 视频一区二区三区自拍 | 色噜噜狠狠一区二区三区 | 毛片在线播放视频 | 视频一区二区在线播放 | 一二三四视频社区5在线高清视频 | 免费一级做a爰片性色毛片 免费一看一级毛片人 | 在线播放一区二区精品产 | 韩国毛片 | 中文字幕精品在线观看 | 国产精品手机在线观看 | 色播视频在线观看 | 扒开双腿猛进入无遮挡软件 | 色多多www网站| 国产综合欧美日韩视频一区 | 亚洲一区精品伊人久久 | 视频一区二区三区在线观看 | 五月婷网| 久久大胆人体 | 一区二区中文字幕 | 综合激情区视频一区视频二区 | 精品伊人久久香线蕉 | 国产一区二区三区在线免费 | 国产精亚洲视频 | 欧美另类人交videos新 | 在线国产91| 欧美日韩国产超高清免费看片 |