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 】
相关推荐:
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
PHP 500报错的快速解决方法
如何彻底删除建站之星生成的Banner?
详解Android图表 MPAndroidChart折线图
敲碗10年!Mac系列传将迎来「触控与联网」双革新
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】
如何撰写建站申请书?关键要点有哪些?
黑客入侵网站服务器的常见手法有哪些?
如何用JavaScript实现文本编辑器_光标和选区怎么处理
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】
zabbix利用python脚本发送报警邮件的方法
Laravel如何实现API速率限制?(Rate Limiting教程)
Laravel distinct去重查询_Laravel Eloquent去重方法
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
如何挑选优质建站一级代理提升网站排名?
,南京靠谱的征婚网站?
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
bootstrap日历插件datetimepicker使用方法
做企业网站制作流程,企业网站制作基本流程有哪些?
Laravel怎么清理缓存_Laravel optimize clear命令详解
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
,网页ppt怎么弄成自己的ppt?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
Bootstrap整体框架之JavaScript插件架构
Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
详解Oracle修改字段类型方法总结
Laravel Fortify是什么,和Jetstream有什么关系
Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程
如何在橙子建站上传落地页?操作指南详解
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
佛山企业网站制作公司有哪些,沟通100网上服务官网?
使用PHP下载CSS文件中的所有图片【几行代码即可实现】
企业网站制作这些问题要关注
太平洋网站制作公司,网络用语太平洋是什么意思?
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
利用JavaScript实现拖拽改变元素大小
网易LOFTER官网链接 老福特网页版登录地址
javascript读取文本节点方法小结
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践


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