Ajax 板


LINE

<html> <audio id="audio1" src="1.wav"></audio> <audio id="audio2" src="2.wav"></audio> <audio id="audio3" src="3.wav"></audio> <button onclick="play()">Start</button> <script> var play = function() { 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]); } } </script> </html> 您的范例我看到了,是可以正常执行的 但是我套用上去就不行了 到底是发生了什麽事??? >_< ※ 引述《Kenqr (function(){})()》之铭言: : ※ 引述《shadowjohn (转角遇到爱)》之铭言: : : 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), 来自: 104.237.91.152
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Ajax/M.1479998651.A.2EF.html
1F:推 eight0: 这和this有关 把 audioX.play 改成 function(){ 11/24 23:41
2F:→ eight0: audioX.play()} 11/24 23:41
3F:推 TETZ: 应该是audioPlay[i]要变成audioPlay[i]()吧 11/25 00:38
4F:→ TETZ: 欸不对 原本那样应该ok不然就是用楼上的方法 11/25 00:40
5F:→ xdraculax: 加上 document.getElementById 11/25 07:01







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灯, 水草

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

TOP