php - 具有动态源的 HTML5 音频元素

标签 php html audio

我有一个基本的音频播放器:

<audio controls="controls" autoplay="true" loop="loop">
<source src="song.php" type="audio/mpeg" />
</audio>

我没有直接指向 MP3 文件的源代码,而是指向一个 PHP 文件,然后该文件指向 MP3 文件,这样就可以了。但是,当当前轨道结束时,PHP 文件指向一个新的 MP3 文件。所以,我遇到的问题是,当播放器循环播放新的 MP3 文件时,它会完全停止工作。有没有办法解决?有没有办法通过播放列表或任何其他播放器做到这一点?

最佳答案

从您的 duplicate question 复制:


对于初学者来说,每次单击元素时,您都会附加一个新的事件处理程序。如果有人经常暂停音乐,他们就会遇到问题。

相反,试试这个:

<audio id="audio" autoplay controls src="song.php" type="audio/mpeg"></audio>
<script type="text/javascript">
    document.getElementById('audio').addEventListener("ended",function() {
        this.src = "song.php?nocache="+new Date().getTime();
        this.play();
    });
</script>

我假设 song.php 是一个返回音频数据的 PHP 文件。 nocache 查询参数将确保每次实际调用该文件。

关于php - 具有动态源的 HTML5 音频元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14190160/

相关文章:

php - 进行实时、可扩展的音频处理的最佳策略?

javascript - Ajax 提交 ajax 加载的表单

php - 我使用哪个用户名/密码连接到 mySQL

javascript - 通过PHP调用JS函数

javascript - 如何防止自定义光标移动字母?

android - 如何知道媒体播放器控件是否正在播放音乐?

apache-flex - 弹性 : how to change the volume of an EMBEDDED sound?

php - 在php中将单列数据合并为双列数据

html - 使用 CSS 或可能的替代方案来设计 'title' 属性?

html - 尽管 z-index 内容仍超出固定导航栏的顶部