网页中视频内容自动播放

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

  1. 静音播放。只要将video设置为muted,然后就可以自动播放了。
  2. 引导用户点击后再进行播放。此处的点击是只要用户点击过页面的任何位置,然后就可以调用video.play()进行播放了。不是一定要点击视频部分,但是一定是要用户在此页面进行了交互.
  3. 在pc上,已经超过了用于的“媒体参与度索引"阈值,这意味着该用户以前曾播放带声音的视频,就可以自动播放。此部分个人理解是类似视频网站的白名单。
  4. 通过iframe的方式加载带音视频的网页。
  5. 此页面已经获取了使用音视频设备权限。就是此页面可以获得了使用麦克风和摄像头的权限。具体方法可以参考获取浏览器麦克风、摄像头和屏幕共享

修改浏览器设置

以Chrome为例子,现打开要播放视频的网站,点击url左边的icon,在弹出菜单中选择网站设置
在这里插入图片描述
然后在新页面中找到声音,然后将声音设置为允许
在这里插入图片描述
然后就可以自动播放带声音的媒体了。此设置是针对域名的,所以要先打开要播放视频的网站,然后再进行设置。

静音播放

<html>
  <head>
    <title>mute autoplay</title>
  </head>
  <body>
    <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

引导用户点击

<html>
  <head>
    <title>user action</title>
  </head>
  <body>
    <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了

获取音视频权限

<html>
  <head>
    <title>autoplay</title>
  </head>
  <body>
    <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

尝试播放,失败后再处理

<html>
  <head>
    <title>autoplay</title>
  </head>
  <body>
    <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
      })
    </script>
  </body>
</html>

尝试自动播放demo,如果播放成功,则正常,如果不成功则显示播放按钮,点击后可以正常播放。

其他

如果你也是专注前端多媒体或者对前端多媒体感兴趣,可以关注微信公众号“前端多媒体”

  • 26
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

豆包啊啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值