HTML/JS - 在页面加载时播放音频文件

Posted

技术标签:

【中文标题】HTML/JS - 在页面加载时播放音频文件【英文标题】:HTML/JS - Play audio file on page load 【发布时间】:2021-01-04 17:33:14 【问题描述】:

我会在打开网站后播放音频文件(循环播放)。 我知道浏览器对自动播放有限制,但是否可以使用 javascript 自动播放任何音频? 谢谢!

【问题讨论】:

这能回答你的问题吗? How to make audio autoplay on chrome @KarthikRadhakrishnan 我已经尝试过了,但它不起作用! 【参考方案1】:

目前没有任何保证的方法; MDN 有following general guidance:

作为一般规则,您可以假设只有在以下至少一项为真时才允许媒体自动播放:

音频已静音或音量设置为 0 用户与网站进行了交互(通过点击、敲击、按键等) 如果网站已被列入白名单;如果浏览器确定用户经常与媒体互动,这可能会自动发生,也可能通过首选项或其他用户界面功能手动发生 如果自动播放功能策略用于向 an 及其文档授予自动播放支持。 否则,播放可能会被阻止。导致阻止的确切情况以及网站如何被列入白名单的具体情况因浏览器而异,但以上是很好的指导方针。

Chrome 和 Safari 的当前政策是,您不能只在页面加载后播放音频(除非它被静音)。

Chrome 有 following policies:

始终允许静音自动播放。 在以下情况下允许自动播放声音: 用户与域进行了交互(点击、点击等)。 在桌面上,用户的媒体参与指数阈值已被超过,这意味着用户之前播放过有声视频。 用户已将网站添加到移动设备的主屏幕或在桌面设备上安装了 PWA。 ***框架可以将自动播放权限委托给其 iframe 以允许自动播放声音。

Safari 有关于自动播放的following guidance:

网站应假定使用或需要用户手势点击才能播放。 检测自动播放是否被拒绝很重要,因为用户现在可以关闭所有形式的自动播放,包括无声视频。 自动播放限制是按元素授予的。

【讨论】:

是的,我已经看到了这些规则,有什么方法可以在不违反任何规则的情况下增加音频的音量(从 0 开始)? Afaik 没有。据我了解,更改音量将使浏览器重新评估这些规则。

以上是关于HTML/JS - 在页面加载时播放音频文件的主要内容,如果未能解决你的问题,请参考以下文章

在完成播放之前再次单击播放音频文件

JavaScript - PC 端通过纯 js 播放音频文件(播放提示音)

Javascript 音频不会停止并同时播放多个音轨

从 mp4 中提取音轨并将其保存到可播放的音频文件中

在 iOS Safari 中播放音频时如何设置缩略图?

jq页面加载事件,页面加载完调用音频自动播放怎么写?