首页前端开发HTML如何解决layer弹出层中H5播放器全屏出错

如何解决layer弹出层中H5播放器全屏出错

时间2024-01-23 13:39:56发布访客分类HTML浏览1012
导读:收集整理的这篇文章主要介绍了如何解决layer弹出层中H5播放器全屏出错,觉得挺不错的,现在分享给大家,也给大家做个参考。本文主要介绍了layer弹出层中H5播放器全屏出错解决&属性poster底图占满video的方法,具有很好的参...
收集整理的这篇文章主要介绍了如何解决layer弹出层中H5播放器全屏出错,觉得挺不错的,现在分享给大家,也给大家做个参考。本文主要介绍了layer弹出层中H5播放器全屏出错解决& 属性poster底图占满video的方法,具有很好的参考价值,下面跟着小编一起来看下吧

1.

在layer弹窗组件中

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

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

举个栗子

!DOCTYPE html>
    html>
    head>
     meta charset="utf-8">
     tITle>
    /title>
     script src="http://lib.sinaapp.COM/js/jquery/1.9.1/jquery-1.9.1.min.js">
    /script>
     script src="layer/layer.js">
    /script>
     style>
     /style>
    /head>
    body>
    h1>
    我是字/h1>
    p id="box">
    video id="video" controls PReload="auto" width="400px" height="300px">
     source src="http://movie.ks.js.cn/flv/other/1_0.mp4" type="video/mp4">
    /video>
    /p>
    script>
 layer.open({
 type: 1, title: false, shadeClose: true, area: ['400px', '350px'], content: $('#box'), success: function(layero){
 }
 }
    );
    /script>
    /body>
    /html>
    

可以看到全屏不正常了

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

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

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.

@R_126_842@的poster属性指代视频未播放前放置的一张图片

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

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

举个栗子

p 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>
    /p>
    

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

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

p 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>
    /p>
    

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;
  }
    

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

html5和css3以及jquery实现音乐播放器

关于Html5中video标签浏览器兼容性增强的方案分享

以上就是如何解决layer弹出层中H5播放器全屏出错的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

layer全屏

若转载请注明出处: 如何解决layer弹出层中H5播放器全屏出错
本文地址: https://pptw.com/jishu/584259.html
利用HTML5 Canvas实现打飞机游戏 html5 touch事件实现触屏页面上下滑动

游客 回复需填写必要信息