作者iamshuichi (vincent)
看板Ajax
標題[問題] setTimeout與迴圈的問題
時間Thu Nov 24 00:15:18 2016
audioPlay=[audio1.play(), audio2.play(), audio3.play();
time=[0, 500, 1000];
for (var i=0; i<3; i++) {
setTimeout("audioPlay[i]", time[i]);
}
上面這段程式,我希望audio1播完之後
等待500毫秒之後播audio2
再等待500毫秒後播audio3
但是失敗了,我猜迴圈大概不能這樣寫吧!
於是我修改了一下
for (var i=0; i<3; i++) {
setTimeout("audioPlay[i]", 500);
}
結果還是不行,三個聲音同時出來
看來JavaScript是先等500毫秒
再同時執行前面的三個函數
如果想達到我的目的
不知道該怎麼寫呢?
--
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 104.237.91.82
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Ajax/M.1479917722.A.D7D.html
1F:→ ninetyeight: audioPlay=[audio1, audio2, audio3] 11/24 00:29
2F:→ ninetyeight: setTimeout(function(){audioPlay[i].play()},time[i 11/24 00:29
3F:推 youtuuube000: 改成setTimeout(audioPlay[i], time[i]); 應該可行 11/24 04:02
4F:→ youtuuube000: 因為""裡面是字串 因此i是字元 不會隨著for的i改變 11/24 04:03
5F:推 TETZ: 我記得setTimeout+for loop的話要用IIFE不然i都會是一樣的 11/24 04:13
7F:→ TETZ: 應該說你第一個解法要搭配IIFE第二個的話可以在setTimeout 11/24 04:15
8F:→ TETZ: 裡另外加兩個setTimeout來跑? 11/24 04:17
10F:→ TETZ: 這個比較清楚 11/24 04:19
11F:→ TETZ: 因為當你執行setTimeout時那些i已經變成2了js的變數是跟著 11/24 04:30
12F:→ TETZ: 記憶體的address除非你另外assign一個變數去存 11/24 04:30
13F:→ xdraculax: 最早的錯誤是組成陣列時已播放,另外i 的問題可改 setT 11/24 09:47
14F:→ xdraculax: imeout(audoPlay[i].play, time[i]) 11/24 09:47
15F:→ iamshuichi: 感謝幾位大大的指導,我研究看看! 11/24 21:44