0

0

HTML音频播放列表怎么创建_HTML媒体多文件管理汇总【技巧】

雪夜

雪夜

发布时间:2026-03-15 22:24:32

|

322人浏览过

|

来源于php中文网

原创

用<audio>标签实现多音频顺序播放需JavaScript监听ended事件,手动切换src并调用play();须确保用户交互触发、每次切换前调用load()、重置currentTime=0,用数组管理路径;new Audio()不可直接播放,MediaSession需手动处理播放逻辑且兼容性有限;preload="metadata"不预加载音频主体,真预加载需fetch+createObjectURL。

html音频播放列表怎么创建_html媒体多文件管理汇总【技巧】

怎么用 <audio> 标签实现多个音频文件顺序播放

原生 <audio> 不支持内置播放列表,必须靠 JavaScript 控制切换和自动续播。核心是监听 ended 事件,手动加载下一个 src 并调用 play()

常见错误现象:play() 被静音策略拦截(尤其在非用户交互后)、切换时卡顿、currentTime 没重置导致从中间开始播。

  • 播放前确保当前 <audio> 元素已获得用户交互(如点击按钮触发首次播放)
  • 每次切换前调用 load(),否则部分浏览器可能复用旧解码器状态,引发异常
  • audio.currentTime = 0play(),避免上一曲残留时间影响
  • 用数组管理路径,用索引跟踪当前项,不要依赖 DOM 顺序或 data-* 属性动态读取(易错且慢)

Audio 构造函数 + play() 链式调用为什么失败

直接 new Audio(src) 后立刻 play() 几乎必失败——它不绑定到页面上下文,缺少用户激活信号,且无法监听 ended

使用场景仅限预加载或检测格式支持(canPlayType()),不能替代页面内 <audio> 元素做播放控制。

立即学习前端免费学习笔记(深入)”;

  • new Audio() 创建的实例没有 DOM 节点,addEventListener('ended', ...) 无效
  • 移动端 Safari 对非 DOM 绑定音频的 play() 直接抛 NotAllowedError
  • 若需后台预加载,用 fetch() + ArrayBuffer 缓存,但播放仍需注入 <audio> 元素

MediaSession 管理多曲播放时容易漏掉什么

MediaSession 能让系统媒体控件显示曲名、支持快进/跳过,但它不负责播放逻辑——只是“贴标签”,所有跳曲、暂停、进度更新仍要自己写。

Summarizer
Summarizer

基于 AI 的文本段落摘要生成器

下载

兼容性注意:Chrome ≥ 73、Edge ≥ 79 支持完整 API;Firefox 仅部分支持(无 setActionHandler);Safari 完全不支持。

  • 必须在用户交互后(如 click)才可调用 navigator.mediaSession.setActionHandler(),否则静默失败
  • mediaSession.metadata 必须是 MediaMetadata 实例,传普通对象会报错 TypeError: Illegal constructor
  • 跳曲时需同步更新 mediaSession.positionState(含 durationplaybackRate),否则锁屏界面进度条不动

为什么用 preload="metadata" 但首曲还是延迟加载

preload="metadata" 只保证获取时长、封面等元数据,不提前下载音频主体。真正解码和缓冲仍发生在 play() 调用时。

性能影响明显:Wi-Fi 下感知弱,4G 或弱网下首曲等待超 1 秒很常见;连续切换时,未预加载的下一曲必然卡顿。

  • 想真预加载,得用 fetch(src).then(r => r.arrayBuffer()) + URL.createObjectURL(),再赋给 audio.src
  • 但注意内存:大量音频缓存会触发 Chrome 的 DOMException: QuotaExceededError
  • 更稳妥的做法是只预加载当前曲 + 下一曲(双缓冲),其余保持 preload="none"

事情说清了就结束。多文件播放最麻烦的从来不是“怎么列出来”,而是每个环节都卡在浏览器策略边缘——用户交互时机、加载状态判断、错误恢复路径,少盯住一个,列表就断在第三首。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1077

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

848

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1745

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

398

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1041

2025.04.24

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4380

2024.08.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

68

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

108

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

324

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

AngularJS教程
AngularJS教程

共24课时 | 4.2万人学习

CSS教程
CSS教程

共754课时 | 43.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号