html5audio标签播放结束怎么触发事件_onended回调方法【教程】
发布时间 - 2025-12-31 00:00:00 点击率:次推荐使用 addEventListener 绑定 ended 事件,需在 loadedmetadata 后注册以确保兼容性;onended 属性因只能绑定单个回调且无法控制捕获/冒泡阶段而不推荐。
HTML5 标签播放结束时,直接监听 ended 事件即可触发回调,不需要额外封装或 polyfill —— 原生支持,但容易因加载状态、静音策略或错误中断而失效。
为什么 onended 属性不推荐用
onended 是 DOM 元素的属性式事件处理器(如 audio.onended = function() {...}),它只能绑定一个回调,且无法控制事件捕获/冒泡阶段;现代写法统一用 addEventListener 更可靠。
- 多个监听器会互相覆盖(后赋值的覆盖前一个)
- 无法在回调中使用
removeEventListener精确解绑 - 若音频未成功加载(
networkState === 0)或中途报错(error事件),ended永远不会触发
正确绑定 ended 事件的写法
确保 已加载元数据(loadedmetadata)后再绑定,避免因元素未就绪导致监听失败。
const audio = document.querySelector('audio');
audio.addEventListener('loadedmetadata', () => {
audio.addEventListener('ended', () => {
console.log('播放已自然结束');
// 这里写你的逻辑:跳转下一曲、显示按钮、重置UI等
});
});
- 必须等
loadedmetadata或至少canplay后再监听ended,否则 Safari 和部分 Android WebView 可能漏触发 - 不要在
DOMContentLoaded就绑 —— 此时audio.src可能还没解析完成 - 如果使用动态设置
src(例如audio.src = 'xxx.mp3'),需在赋值后手动调用audio.load(),再监听loadedmetadata
常见失效场景和排查点
ended 不触发,大概率不是监听写错了,而是播放流程被干扰。
-
audio.play()被用户手势拦截(Chrome 66+ 要求首次播放由 click/tap 触发),此时play()返回 Promise 并 reject,后续任何事件都无效 - 音频被静音或音量设为 0,但
ended仍会触发 —— 注意区分“没声音”和“没播放” - 播放中调用了
audio.pause()或audio.currentTime跳转,不会触发ended;只有自然播到末尾才触发 - MP3 文件缺少合法 ID3 或末尾帧损坏,某些浏览器(尤其是 iOS
Safari)会提前终止播放,不发 ended - 使用了
loop="true"—— 循环模式下永远不会触发ended
真正麻烦的不是怎么写回调,而是得同时处理 error、abort、stalled 这些可能截断播放的事件;ended 只代表“顺利走到了最后一帧”,不代表你预期的业务流程一定完成。
# html
# android
# html5
# 处理器
# 浏览器
# safari
# ios
# 事件捕获
# 为什么
# chrome
# 封装
# Error
# 循环
# function
# 事件
# dom
# promise
# webview
# 绑定
# 回调
# 加载
# 跳转
# 永远不会
# 还没
# 尤其是
# 首次
# 多个
# 不需要
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
音乐网站服务器如何优化API响应速度?
免费视频制作网站,更新又快又好的免费电影网站?
Laravel怎么连接多个数据库_Laravel多数据库连接配置
canvas 画布在主流浏览器中的尺寸限制详细介绍
Linux安全能力提升路径_长期防护思维说明【指导】
Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
深入理解Android中的xmlns:tools属性
Laravel如何使用Service Container和依赖注入?(代码示例)
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
如何快速配置高效服务器建站软件?
微信小程序 scroll-view组件实现列表页实例代码
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
Laravel PHP版本要求一览_Laravel各版本环境要求对照
如何在宝塔面板创建新站点?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】
iOS发送验证码倒计时应用
python中快速进行多个字符替换的方法小结
javascript日期怎么处理_如何格式化输出
Laravel如何生成URL和重定向?(路由助手函数)
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
如何在云指建站中生成FTP站点?
SQL查询语句优化的实用方法总结
Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
如何在万网主机上快速搭建网站?
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何确认建站备案号应放置的具体位置?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何快速搭建自助建站会员专属系统?
如何快速搭建个人网站并优化SEO?
Laravel如何实现模型的全局作用域?(Global Scope示例)
中国移动官方网站首页入口 中国移动官网网页登录
黑客入侵网站服务器的常见手法有哪些?
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
如何登录建站主机?访问步骤全解析
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Java类加载基本过程详细介绍
如何快速选择适合个人网站的云服务器配置?
如何用虚拟主机快速搭建网站?详细步骤解析
Laravel怎么清理缓存_Laravel optimize clear命令详解
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全
如何快速搭建虚拟主机网站?新手必看指南


Safari)会提前终止播放,不发