Ajax 板


LINE

抱歉,原本的写法有错。 函数被 setTimeout 呼叫的时候,this 会被设定成 window, 所以呼叫有用到 this 的函数就会出问题。 这里比较常见的作法是使用 closure 处理: var audios = [audio1, audio2, audio3]; var time = [0, 500, 1000]; for(var i=0; i<3; i++) { (function(index){ setTimeout(function(){ audios[index].play(); }, time[i]); })(i); } 这里直接用 audios[i].play() 的话会有错, 因为离开回圈後 i 的值固定是 3, setTimeout 的时间到时就会变成执行audios[3].play()。 用 closure 包起来後, 外面的 function 每次执行会产生一个新的环境,一共 3 个。 每个环境有自己的 index,即使 i 改变了,index也不会受到影响。 另外也可以用 bind: var audios = [audio1, audio2, audio3]; var time = [0, 500, 1000]; for(var i=0; i<3; i++) { setTimeout(audios[i].play.bind(audios[i]), time[i]); } 因为懒了所以就不解释了XD ※ 引述《iamshuichi (vincent)》之铭言: : <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(){})()》之铭言: : : 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.1480059627.A.71E.html
1F:推 iamshuichi: 谢谢你,成功了,虽然原理还有点不太懂 11/27 03:21
2F:→ iamshuichi: 我再好好思考一下 11/27 03:21







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

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

TOP