gpt4 book ai didi

javascript - 如何循环遍历多个音频文件并使用 javascript 顺序播放它们?

转载 作者:太空狗 更新时间:2023-10-29 14:23:30 35 4
gpt4 key购买 nike

点击一个按钮我想播放 4 个音频,三个音频来自兄弟 ID,最后一个来自被点击的 ID。请帮我解决这个问题。

我已更改代码,但音频仍未按顺序播放。最后一个音频首先播放,然后是第二个和第三个,音频之间没有足够的间隔。

$(document).on('click', '.phonics_tab .audioSmImg_learn', function () {
var PID = '#' + $(this).parents('.phonics_tab').attr('id');
audioFileName = 'audio/' + $(this).attr('id') + '.mp3';
var audioElmnt = {};
var audioFileName1 = {};

$(PID + ' .word_box_item').each(function (inx, i) {
if (inx >= 1) {
audioElmnt[inx - 1].pause();
audioElmnt[inx - 1].currentTime = 0;
}
audioElmnt[inx] = document.createElement('audio');
audioElmnt[inx].setAttribute('autoplay', 'false');
audioFileName1[inx] = 'audio/' + $(this).children('h2').attr('id') + '.mp3';
audioElmnt[inx].setAttribute('src', audioFileName1[inx]);
audioElmnt[inx].load();

//in previous code your inx only run for the last item.
playAudio(audioElmnt[inx], 300); // here the object will be sent to the function and will be used inside the timer.
});

function playAudio(audioElmnt, delay){
setTimeout(function () {
audioElmnt.play();
}, delay);
}

setTimeout(function () {
audioElement.currentTime = 0;
audioElement.pause();
audioElement.setAttribute('src', audioFileName);
audioElement.load();
audioElement.play();
}, 500);
});

最佳答案

您不应该在循环中使用 setTimeout,它与所有其他编程语言的行为不同。您的解决方案应该是这样的。在之前的代码中,您的变量 inx 仅针对最后一项运行。

$(document).on('click', ' .audioImg', function () {
var ParentID = '#' + $(this).parents('.parent').attr('id');
audioFileName = 'audio/' + $(this).attr('id') + '.mp3';
var audioElmnt = {};
var audioFileName1 = {};

$(PID + ' .item').each(function (inx, i) {
if (inx >= 1) {
audioElmnt[inx - 1].pause();
audioElmnt[inx - 1].currentTime = 0;
}

audioElmnt[inx] = document.createElement('audio');
audioElmnt[inx].setAttribute('autoplay', 'false');
audioFileName1[inx] = 'audio/' + $(this).children('h2').attr('id') + '.mp3';
audioElmnt[inx].setAttribute('src', audioFileName1[inx]);

audioElmnt[inx].load();

//in previous code your inx only run for the last item.
playAudio(audioElmnt[inx], 150); // here the object will be sent to the function and will be used inside the timer.

});
var playAudio = function(audioElmnt, delay){
setTimeout(function () {
audioElmnt.play();
}, delay);
}
setTimeout(function () {
audioElement.currentTime = 0;
audioElement.pause();
audioElement.setAttribute('src', audioFileName);
audioElement.load();
audioElement.play();
}, 500);
});

关于javascript - 如何循环遍历多个音频文件并使用 javascript 顺序播放它们?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37294380/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com