解决layer弹出层中H5播放器全屏出错的方法-创新互联

小编给大家分享一下解决layer弹出层中H5播放器全屏出错的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

成都创新互联作为成都网站建设公司,专注成都网站建设、网站设计,有关企业网站制作方案、改版、费用等问题,行业涉及餐厅设计等多个领域,已为上千家企业服务,得到了客户的尊重与认可。

1.

在layer弹窗组件中

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

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

举个栗子




 
 
 
 
 


我是字

解决layer弹出层中H5播放器全屏出错的方法

解决layer弹出层中H5播放器全屏出错的方法

可以看到全屏不正常了

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

解决layer弹出层中H5播放器全屏出错的方法

解决layer弹出层中H5播放器全屏出错的方法

解决layer弹出层中H5播放器全屏出错的方法

所以,目前的解决办法是在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);
 }
 });

解决layer弹出层中H5播放器全屏出错的方法

2.

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

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

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

举个栗子

解决layer弹出层中H5播放器全屏出错的方法

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

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

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

解决layer弹出层中H5播放器全屏出错的方法

看完了这篇文章,相信你对解决layer弹出层中H5播放器全屏出错的方法有了一定的了解,想了解更多相关知识,欢迎关注创新互联成都网站设计公司行业资讯频道,感谢各位的阅读!

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


标题名称:解决layer弹出层中H5播放器全屏出错的方法-创新互联
本文链接:http://scyanting.com/article/egiss.html