2019-7-19 seo達(dá)人
如果您想訂閱本博客內(nèi)容,每天自動(dòng)發(fā)到您的郵箱中, 請(qǐng)點(diǎn)這里
for(var i = 0; i < 5; i++) {
console.log(i)
}
這樣for循環(huán)可打印出 0 - 4的結(jié)果
for(var i = 0; i < 5; i++) {
setTimeout(function() {
console.log(i)
}, i * 1000)
}
但這樣只能間隔一秒打印出5個(gè)5
原因在于 setTimeout是異步,等f(wàn)or循環(huán)全部完成 i 后才會(huì)執(zhí)行
解決方法可以將 for循環(huán)中的var 變成 let
let只作用于for循環(huán)內(nèi),這樣每次付給setTimeout的值都是當(dāng)前值
或者在setTimeout外再包一層function
for(var i = 0; i < 5; i++) {
(function(i) {setTimeout(function() {
console.log(i)
}, i * 1000)})(i)
}
將 i 作為參數(shù)傳到setTimeout中運(yùn)行 這樣就可以得到每隔1秒加1的log結(jié)果了
藍(lán)藍(lán)設(shè)計(jì)( www.b186.net )是一家專(zhuān)注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計(jì)、網(wǎng)站建設(shè) 、平面設(shè)計(jì)服務(wù)。
藍(lán)藍(lán)設(shè)計(jì)的小編 http://www.b186.net