关于Safari 中禁止音视频自动播放的问题:
苹果为了用户着想,禁止了
Autoplay
和JS "onload"
加载播放,也就是说即使你在html文件里使用了preload
和autoplay
属性,在移动版 Safari
上,此属性会被忽视,并且不会加载视频流,甚至不会下载该视频流。除非用户物理点击一次媒体播放。
Safari 中通过 playsinline + muted 实现媒体自动播放
其实从
ios10
开始 safari 重新支持了自动播放,不过有前置条件,需要在video
或audio
添加muted
属性并且设置为true
(或者视频本身没有音轨),这样设置了muted
(静音)的媒体标签就符合自动播放的规则了,不过单单设置了 muted 并不能自动播放,还有另外一个关键属性,那就是playsinline
属性,这个属性可以让我们的媒体在浏览器中不必以全屏的形式播放,众所周知,在 ios 中媒体播放默认都以全屏形式播放,加上playsinline
即可不全屏播放媒体,nice~。
<video id="webcam" controls autoplay playsinline muted />
给 video 设置了以上属性后,那么就已经实现了视频的自动播放了,然后另一个问题就来了,现在是静音播放的状态,如何取消静音呢?可以在 window.onload() 等事件中取消 video 标签静音状态即可,即完美实现媒体自动播放。
window.onload = () => {
document.getElementById('webcam').muted = false;
}