Web 浏览器自动播放音视频

发布于 2024-10-20 22:13:16 字数 2549 浏览 8 评论 0

现代浏览器为了防止恶意骚扰,当用户没有互动(点击、触摸等)前,不能直接播放(声音)视频。但是也有额外的方式来允许直接播放,各家浏览器不一样。

Chrome 66+

参考链接: https://developer.chrome.com/blog/autoplay/

Chrome 的自动播放策略:

  • 声音关闭的视频可以自动播放,如 twitter、微博
  • 带声音的满足以下情况可以播放
  • 顶层 frame 代理权限(没看懂)

Media Engagement Index

这个分数和用户观看时间、声音、屏幕大小有关;可以在 about://media-engagement 查看

实测分数超过 0.3 就能自动播放了。

sss

Safari

搜到篇关于自动播放的文章: https://webkit.org/blog/7734/auto-play-policy-changes-for-macos/

Safari in macOS High Sierra uses an automatic inference engine to block media elements with sound from auto-playing by default on most websites. Safari 11 also gives users control over which websites are allowed to auto-play video and audio by opening Safari’s new “Websites” preferences pane, or through the “Settings for This Website…” option in the Safari menu.

和 Firefox 相似都有个选项可以直接调整自动播放的行为。

截屏 2022-05-25 21 35 07

看看 B 站直播在禁用自动播放有声音的视频以后:

截屏 2022-05-25 21 36 46

最佳实践

捕获 play 抛出的 promise:

var promise = document.querySelector('video').play();

if (promise !== undefined) {
    promise.catch(error => {
        // Auto-play was prevented
        // Show a UI element to let the user manually start playback
    }).then(() => {
        // Auto-play started
    });
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

稍尽春風

暂无简介

0 文章
0 评论
24 人气
更多

推荐作者

emdigitizer10

文章 0 评论 0

残龙傲雪

文章 0 评论 0

奢望

文章 0 评论 0

微信用户

文章 0 评论 0

又爬满兰若

文章 0 评论 0

独孤求败

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文