Web 浏览器自动播放音视频
现代浏览器为了防止恶意骚扰,当用户没有互动(点击、触摸等)前,不能直接播放(声音)视频。但是也有额外的方式来允许直接播放,各家浏览器不一样。
Chrome 66+
参考链接: https://developer.chrome.com/blog/autoplay/
Chrome 的自动播放策略:
- 声音关闭的视频可以自动播放,如 twitter、微博
- 带声音的满足以下情况可以播放
- 用户互动后
- Media Engagement Index 分数够高
- 被添加到 PWA 或者 手机桌面
- 顶层 frame 代理权限(没看懂)
Media Engagement Index
这个分数和用户观看时间、声音、屏幕大小有关;可以在 about://media-engagement 查看
实测分数超过 0.3 就能自动播放了。
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 相似都有个选项可以直接调整自动播放的行为。
看看 B 站直播在禁用自动播放有声音的视频以后:
最佳实践
捕获 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 技术交流群。
上一篇: vite 开发技巧
下一篇: 不要相信一个熬夜的人说的每一句话
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论