网页中视频内容自动播放

目前主流的浏览器中已经禁止带声音的媒体自动播放。具体内容在这里 chrome自动播放策略 (可能国内网络访问不了)。此处重点是 带声音 的媒体 自动播放
里面也说明了集中播放的方式

  • 静音播放。只要将video设置为muted,然后就可以自动播放了。

  • 引导用户点击后再进行播放。此处的点击是只要用户点击过页面的任何位置,然后就可以调用video.play()进行播放了。不是一定要点击视频部分,但是一定是要用户在此页面进行了交互.

  • 在pc上,已经超过了用于的“媒体参与度索引"阈值,这意味着该用户以前曾播放带声音的视频,就可以自动播放。此部分个人理解是类似视频网站的白名单。

  • 通过iframe的方式加载带音视频的网页。

  • 此页面已经获取了使用音视频设备权限。就是此页面可以获得了使用麦克风和摄像头的权限。具体方法可以参考 获取浏览器麦克风、摄像头和屏幕共享
    下面来说一下可以解决的方法。

  • 修改浏览器设置

    以Chrome为例子,现打开要播放视频的网站,点击url左边的icon,在弹出菜单中选择网站设置

    </head> <video id="video" style="width: 640px; height: 480px;" src="xxx.mp4" muted autoplay ></video> <button id="unmuteButton" >unmute</button> <script> let button = document.getElementById("unmuteButton"); let video = document.getElementById("video"); button.addEventListener("click", function() {\p video.muted = false; </script> </body> </html>

    默认静音播放,如果点击按钮就可以取消静音了。当然也可以直接用document获取click,不需要按钮也是可以的。 静音播放Demo

    引导用户点击

    <title>user action</title> </head> <video id="video" style="width: 640px; height: 480px;" src="xxx.mp4" ></video> <button id="playButton" >play</button> <script> let button = document.getElementById("playButton"); let video = document.getElementById("video"); button.addEventListener("click", function() { video.play(); </script> </body> </html>

    点击按钮后,就可以开始播放了。 点击后播放Demo

    iframe方式

    <!-- Autoplay is allowed. -->
    <iframe src="xxx.html" allow="aotuplay">
    <!-- Autoplay an Fullscreen are allowed. -->
    <iframe src="xxx.html" allow="autoplay; fullscreen">
    

    抱歉,此处测试了一下,貌似还是不能成功播放,上面是官方给出的代码,所以没有Demo了

    获取音视频权限

    <title>autoplay</title> </head> <video id="video" style="width: 640px; height: 480px;" src="xxx.mp4" ></video> <script> let video = document.getElementById("video"); if (navigator && navigator.mediaDevices && navigator.mediaDevices.getUserMedia) { navigator.mediaDevices.getUserMedia({audio: true}).then((mediastream) => { video.play(); }).catch((err) => { alert("getUserMedia error"); console.log('getUserMedia Error:', err); } else { alert("not support getUserMedia"); </script> </body> </html>

    先获取音频权限之后再进行播放,就可以自动播放了获取音频权限后播放Demo

    尝试播放,失败后再处理

    <title>autoplay</title> </head> <video id="video" style="width: 640px; height: 480px;" src="xxx.mp4" ></video> <script> let video = document.getElementById("video"); video.play().then(() => { // autoplay success }).catch((err) => { // show play button or mute video then play again