前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >layer弹出层中H5播放器全屏出错解决 & 属性poster底图占满video的方法

layer弹出层中H5播放器全屏出错解决 & 属性poster底图占满video的方法

作者头像
书童小二
发布2018-09-03 19:26:41
2.2K0
发布2018-09-03 19:26:41
举报
文章被收录于专栏:前端儿前端儿

1.

在layer弹窗组件中

如果使用了flash播放器,全屏是正常的

但若使用了HTML5的播放器,全屏失效

举个栗子

代码语言:javascript
复制
 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4   <meta charset="utf-8">
 5   <title></title>
 6   <script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
 7   <script src="layer/layer.js"></script>
 8 
 9   <style>
10 
11   </style>
12 </head>
13 <body>
14 <h1>我是字</h1>
15 <div id="box">
16 <video id="video" controls preload="auto" width="400px" height="300px">
17   <source src="http://movie.ks.js.cn/flv/other/1_0.mp4" type="video/mp4">
18 </video>
19 </div>
20 
21 <script>
22 
23   layer.open({
24     type: 1,
25     title: false,
26     shadeClose: true,
27     area: ['400px', '350px'],
28     content: $('#box'),
29     success: function(layero){
30     }
31   });
32 
33 </script>
34 </body>
35 </html>

可以看到全屏不正常了

通过调试发现是这个class的处理影响了全屏的展示

所以,目前的解决办法是在layer层创建之后,移除这个class即可(注意在success回调中置于下一轮事件循环)

代码语言:javascript
复制
layer.open({
    type: 1,
    title: false,
    shadeClose: true,
    area: ['400px', '350px'],
    content: $('#box'),
    success: function(layero){
      console.log(layero)

      // hack处理layer层中video播放器全屏样式错乱问题
      setTimeout(function() {
        // $(layero).removeClass('layer-anim');
      }, 0);
    }
  });

2.

video标签的poster属性指代视频未播放前放置的一张图片

如果video容器宽高小于等于poster图的宽高,则图片能充满容器,反之容器左右就会预留黑色栏

除了手动更换一张大图之外,可以结合CSS来控制,实现铺满

举个栗子

代码语言:javascript
复制
<div id="box">
    <video id="video" controls preload="auto" width="700" height="300" poster="../poster.png" >
      <source src="http://movie.ks.js.cn/flv/other/1_0.mp4" type="video/mp4">
    </video>
</div>

现在图片宽度比容器小,没铺满,参考这里的讨论 可以用CSS让其撑开(这里相当于放大了,不想放大需自行更换大图)

poster里放一个透明图片(这里使用了一个1px*1px的base64格式透明图片),再用css定义video的background并将其覆盖住

代码语言:javascript
复制
<div id="box">
    <video id="video" controls preload="auto" width="700" height="300" poster="data:image/gif;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQImWNgYGBgAAAABQABh6FO1AAAAABJRU5ErkJggg==" >
      <source src="http://movie.ks.js.cn/flv/other/1_0.mp4" type="video/mp4">
    </video>
</div>
代码语言:javascript
复制
video {
        background: transparent url('../poster.png') no-repeat 0 0; 
        -webkit-background-size: cover; 
           -moz-background-size: cover; 
             -o-background-size: cover; 
                background-size: cover; 
    }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-02-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.
  • 2.
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档