Ajax 板


LINE

※ 引述《shadowjohn (转角遇到爱)》之铭言: : ※ 引述《iamshuichi (vincent)》之铭言: : : 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毫秒 : : 再同时执行前面的三个函数 : : 如果想达到我的目的 : : 不知道该怎麽写呢? : for (var i=0; i<3; i++) { : setTimeout("audioPlay[i]", 500); : } : 上面这样写是不行的 : 请改成下面这样 : for (var i=0;i<3; i++) { : (function (index) { //加包的一层 : setTimeout(function () { : audioPlay[index]; : }, 500); : })(i); //带入回圈的 i 值,会变成这个加包的function,变成 index 放入 : } : 这样写就不用改太多了 :) var audioPlay = [audio1.play, audio2.play, audio3.play]; var time = [0, 500, 1000]; for(var i=0; i<3; i++) { setTimeout(audioPlay[i], time[i]); } 实际可执行的范例: https://jsfiddle.net/hzrw429z/1/ 第一行的 audio1.play() 拿掉括号改成 audio1.play, 因为这个阵列里要放的是函数而不是函数的执行结果。 写成 audio1.play() 会在执行到宣告阵列这行时就播放了,函数也没存进阵列里。 setTimeout 这行,"audioPlay[i]" 拿掉双引号改成 audioPlay[i]。 因为 setTimeout 传入字串时,是把字串内容当成函数内容执行。 原本的写法会在时间到时取出 audioPlay 阵列第 i 项的值, 取出後没有做任何动作,所以什麽事都没发生。 修正的写法会在呼叫 setTimeout 函数前先取得 audioPlay 的第 i 项, 取得的东西是一个函数,当成参数传给 setTimeout。 所以 3 次呼叫 setTimeout 相当於: setTimeout(audio1.play, 0); setTimeout(audio2.play, 500); setTimeout(audio3.play, 1000); 时间到时可以正确的分别执行 3 个函数。 这个情况不需要使用 IIFE, 因为 audioPlay[i] 是在呼叫 setTimeout 之前就已经取值了。 setTimeout 在时间到时,呼叫第一个参数的函数时已经不会用到 i, 所以即使离开回圈後 i 的值固定是 3,对我们也没有影响。 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 123.193.160.70
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Ajax/M.1479976445.A.58C.html ※ 编辑: Kenqr (123.193.160.70), 11/24/2016 16:35:57
1F:→ iamshuichi: 感谢大大的指导,这篇我比较看得懂,我研究看看! 11/24 21:45
2F:推 iamshuichi: <audio id="audio1" src="1.wav"></audio> 11/24 22:32
3F:→ iamshuichi: <audio id="audio2" src="2.wav"></audio> 11/24 22:32
4F:→ iamshuichi: <audio id="audio3" src="3.wav"></audio> 11/24 22:33
5F:推 No: setTimeout(audio1.play, 0) 这种写法是 anti-pattern 11/25 00:29
6F:→ No: 除非你很清楚自己在做什麽,不然不要这样写 11/25 00:29







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP