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

网友投稿 274 2023-06-09


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

1.

在layer弹窗组件中

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

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

举个栗子

可以看到全屏不正常了

通过调试发现是这个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.

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

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

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

举个栗子

现在图片宽度比容器小,没铺满,参考这里的讨论 可以用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-sizeQAnPVnebmf: cover;

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Angular实现购物车计算示例代码
下一篇:微信小程序 点击控件后选中其它反选实例详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~