我正在使用wavesurfer.js为音频剪辑生成波形,我遇到的问题是我有多个音频文件被拉入一个php
while
循环,而 javascript 似乎只为返回的第一条记录运行..
我将在下面发布我尝试过的内容,如您所见,我试图使其独一无二并运行每个循环,但我已经用尽了想法并在互联网上到处搜索,但没有任何帮助。
PHP:
global $db;
$select = $db->query("SELECT * FROM audio ORDER BY id DESC");
while ($row = $select->fetch_assoc()) {
echo $row["track_title"] . " by " . $row["artist"] . "<br />";
$path = $row['path'];
$path = str_replace("..", "", $path);
$id = $row['id'];
echo"
<div class='waveid' id='".$id."'>
<div class='path' id='".$path."'>
<div class='cursor' id='wave-cursor'></div><canvas id='wave' class='wave-".$id."' width='1024' height='128'></canvas>
</div>
</div>
";
}
JAVASCRIPT:
var id = $(".waveid").attr('id');
var path = $(".path").attr('id');
console.log(id);
console.log(path);
var wavesurfer = Object.create(WaveSurfer);
wavesurfer.init({
canvas: document.querySelector('.wave-'+id),
waveColor: 'violet',
progressColor: 'purple'
});
wavesurfer.load(path);
总而言之,我有一个 while 循环返回所有歌曲数据,其中 mp3 存储在一个文件夹中,文件路径存储在数据库中并正在返回。我正在尝试为每个文件制作一个独特的波形,但由于某种原因,我只能设法为第一条记录获取一个波形。任何帮助将不胜感激。
编辑:如果有人想编辑标题或任何内容/标签,请随时这样做。