麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

JavaScript setTimeout使用閉包功能實現定時打印數值

2019-11-20 10:58:59
字體:
來源:轉載
供稿:網友

我們這次使用setTimeout來實現一個按照時間定時,依次打印數值的例子.其實在早期的時候,也是我經常犯的一個錯誤,或者實現這種能力,似乎js比較牽強,其實是我的錯,哈哈!沒能理解JS強大之處.我們直接進入主題吧!   注意,如果用setInterval來實現的話,那肯定很簡單,這次我們是使用setTimeout.   我們先從最簡單思考入手.那就會寫出下面的代碼.

for(var i = 0; i < 5; i++){ setTimeout(console.log(i),i*1000); } 

這段代碼雖然依次打印了,每個i的值0,1,2,3,4.但是,執行的時間卻沒有起作用.為什么呢? 因為 console.log() 是方法的執行調用,在調用這個方法后,當是馬上執行!,所以沒有達到我們預期的目的。  

那我們繼續看下面一段代碼

for(var i = 0; i< 5; i++ ){ setTimeout(function(){ console.log(i); },i*1000); } 

這里我們使用一個匿名函數包含了打印的console.log來打印i,所以 i這個值是共享的,還沒等到執行第一個setTimeout的時候,for循環已經執行完成,最后的i = 5,所以i 會打印四次   其實我們兩種解決辦法,我們先來看第一種:

var j = 0; function abc(){ console.log("j = "+j); j++; }  for(var i = 0; i < 10; i++ ){ setTimeout(abc,i*1000) } 

這里我們另外一個全局變量來存儲值,每執行一次函數abc,j就加一次,所以執行到setTimeout的時候,就會調用abc函數,所以會達到我們預期的效果,但是這里這個j是一個全局變量,全局變量會造成容易改變其值或者命名沖突等問題.   第二種辦法的實現,我們再次引入閉包函數.因為閉包函數,每一次創建都會存在一個自己的空間來存儲唯一的值.所以利用這個思維.我們把代碼寫成下面的代碼.

for(var i = 0; i < 10; i++ ){ (function(x){ setTimeout(function(){ console.log(x) },x*1000) })(i) }  

我們將i的每一次執行for循環的值,傳給不同創建的閉包函數,這樣每一個閉包函數里存儲的i值,就都不會一樣.所以就是達到我們的想要的結果.

ps:使用閉包對setTimeout進行簡單封裝

在寫js腳本時,經常會用到一些拼寫函數的情況,例如調用setTimeout

var msgalert="test";  function TestAlert(msg)    {     alert(msg)    }        $(document).ready(function () {   $("#btnCancel").click(function (e) {     setTimeout("TestAlert("+msgalert+")",1000);     }); }) 

查了很長時間,為什么就是彈不出對話框呢。檢查了很長時間才發現,原來是少了一對單引號

$(document).ready(function () {   $("#btnCancel").click(function (e) {     setTimeout("TestAlert('"+msgalert+"')",1000);     }); }) 

這樣的寫法容易出錯,還不容易檢查出錯誤,如果使用閉包就可完全避免,改寫如下

 var msgalert="test";   function dalayAlert(msg ,time){    setTimeout(   TestAlert(msg),   time   );   }   function TestAlert(msg)  {   alert(msg)  } $(document).ready(function () {   $("#btnCancel").click(function (e) {    dalayAlert(msgalert,1000)  }); 

由于使用了閉包,也簡單了很多,檢查錯誤也很容易了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 一级免费特黄视频 | 一区视频 | 精品国产99久久久久久宅男i | 美女黄视频在线观看 | 欧美精品久久久久久久久老牛影院 | 美女亚洲综合 | 久久精品欧美电影 | 国内精品久久久久久久星辰影视 | 自拍偷拍亚洲图片 | 日本不卡一区二区三区在线观看 | sesee99| 色欲香天天天综合网站 | 亚洲第一综合 | 石原莉奈日韩一区二区三区 | 媚药按摩痉挛w中文字幕 | 成年人黄视频 | 欧美精品一区二区三区四区 | 视频一区二区三区免费观看 | 日韩字幕在线观看 | 在线播放一区二区三区 | av在线一区二区三区 | 污片在线观看视频 | 国产亚洲高清在线精品不卡 | 欧美精品亚洲人成在线观看 | 久久综合综合久久 | 久久91亚洲人成电影网站 | 中文字幕在线资源 | 91短视频版高清在线观看免费 | 午夜爽爽爽男女免费观看hd | 精品国产一区二区三 | 久久综合综合 | 国产精品性夜天天视频 | 免费毛片播放 | 国产成人精品二区 | 韩国19禁在线 | 久久免费视频在线 | 91九色蝌蚪在线 | 国产免费一级淫片a级中文 99国产精品自拍 | 色天天综合网 | 色婷婷久久久久久 | 毛片在线视频免费观看 |