浏览器自动播放音视频-前端实现方案
创始人
2025-01-11 01:05:20
0

目录

前言

浏览器自动播放策略

策略详情:

实现方案 

方案1: 互动后播放

方案2: 互动后出声

总结


前言

在开发中可能有遇到这样的需求,当用户打开页面后,需要自动播放视频或音频,按理说那就打开页面时play()一下不就搞定了吗,但实际情况很明显不是,不然也没得这篇文章喽,要实现这个需求,我们得先了解一下浏览器自动播放策略。再给出相应解决方案。

浏览器自动播放策略

Chrome浏览器的自动播放策略自Chrome66起生效,动机是改善用户体验

策略详情:

Chrome 的自动播放政策很简单:

  1. 始终允许静音自动播放。
  2. 在以下情况下,带声音的自动播放会被允许:
    1. 用户已经与当前域进行了交互(click、tap)
    2. 在桌面设备上,用户的==媒体参与度==指数阈值已超过,这意味着用户之前播放过有声视频。
    3. 用户已将网站添加到移动设备上的主屏幕或在桌面上安装了 PWA。
  3. 顶部帧可以将自动播放权限委派给其 iframe,以允许自动播放声音。

==媒体参与度(MEI, Media Engagement Index)==

媒体参与度 (MEI) 是衡量个人在网站上使用多媒体的倾向。

它是一个数字,可通过 chrome://media-engagement/ 查看。

数值越高,用户对该站点的媒体参与度越高,就越有机会自动播放。

但对于开发者而言:

        媒体参与度的计算规则无法通过技术手段更改

        媒体参与度的计算规则不同版本的浏览器可能会有变动

 

实现方案

首先呢,我们直接在用户进入页面的时候play(),可以发现视频并没有播放,并且报错Uncaught (in promise) DOMException: play() failed because the user didn't interact with the document first

                        Document                

这个错误的意思是浏览器已经尝试在没有用户交互的情况下播放媒体文件,但是因为这是不允许的,所以浏览器拒绝了该操作。如果没有这个保护机制,那么网站可以在用户不知情的情况下播放音频和视频,这是不安全和不负责任的行为。 

 

方案1: 互动后播放

先尝试自动播放,若发生异常,则引导用户进行互动操作,然后再进行播放

                        互动后播放                

 进入页面后发现不能自动播放,这时显示开始播放按钮,用户点击后开始播放。

方案2: 互动后出声

先静音播放,然后根据是否能自动播放决定是否取消静音,如果:

  1. 能自动播放,取消静音
  2. 不能自动播放,引导用户进行互动操作后取消静音
                        互动后取消静音                

进入页面后静音播放视频,然后判断是否允许自动播放,如果允许,则取消静音,但我们这里不允许,所以显示打开声音按钮。 

引用的index.css文件内容如下:

* {   margin: 0;   padding: 0;   box-sizing: border-box; }  .vdo-container {   width: 50%;   margin: 1em auto;   position: relative; } video {   display: block;   width: 100%; } .modal {   position: absolute;   inset: 0;   background: rgba(0, 0, 0, 0.5);   display: flex;   justify-content: center;   align-items: center;   display: none; } .btn {   border: none;   outline: none;   background: #409eff;   color: #fff;   display: inline-block;   line-height: 1;   white-space: nowrap;   cursor: pointer;   text-align: center;   transition: 0.1s;   font-weight: 500;   user-select: none;   padding: 12px 20px;   font-size: 14px;   border-radius: 4px; } .btn:hover {   background: #66b1ff; } .btn:active {   background: #3a8ee6; } .btn:disabled {   background: #66b1ff80;   cursor: not-allowed; } 

 

 

总结

如果文中出现有瑕疵的地方各位通过评论或者私信联系我,我们一起进步,有兴趣的伙伴可以关注订阅一下:点击查看更多实用技巧及技术

 

相关内容

热门资讯

玩家交流“wpk ai辅助”w... 玩家交流“wpk ai辅助”wpk透视辅助工具的使用教程(WpK)真是存在有挂(新版有挂)-哔哩哔哩...
实测分享"aa po... 实测分享"aa poker有外挂吗"aapoker辅助软件开发机制(真是有挂)-哔哩哔哩1、这是跨平...
研究成果(德州ai辅助)德州a... 研究成果(德州ai辅助)德州ai辅助软件排名(都是存在有挂)-哔哩哔哩这是由厦门游乐互动科技有限公司...
黑科技有挂“wepokeai代... 黑科技有挂“wepokeai代打”wepoke透明挂辅助(辅助挂)切实是有挂(有挂透明挂)-哔哩哔哩...
玩家必看科普!“wpk最新黑科... 玩家必看科普!“wpk最新黑科技”wpk有辅助插件吗(wPK)原本存在有挂(真是有挂)-哔哩哔哩1、...
重大来袭"aapok... 重大来袭"aapoker辅助工具ai"aapoker透视辅助(都是存在有挂)-哔哩哔哩1、用户打开应...
普及知识(德州辅助神器软件)德... 普及知识(德州辅助神器软件)德州之星透牌器(最初有挂)-哔哩哔哩;科技安装教程;136704302。...
黑科技插件“wepoke有没有... 黑科技插件“wepoke有没有挂”wepokeai代打(黑科技ai)本来有挂(有挂助手)-哔哩哔哩;...
指导大家“wpk ai辅助”w... 指导大家“wpk ai辅助”wpk辅助神器(wPK)从前是有挂(有挂详情)-哔哩哔哩;指导大家“wp...
推荐一款"aapok... 推荐一款"aapokerai辅助"aapoker有作弊吗(果然是有挂)-哔哩哔哩;一、aapoker...