最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小OO 时间:2020-11-27 15:05:06
文档

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

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>;<。
推荐度:
导读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>;<。
 本文主要介绍了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.

video标签的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的base格式透明图片),再用css定义video的background并将其覆盖住

<p id="box">
 <video id="video" controls preload="auto" width="700" height="300" poster="data:image/gif;base,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; 
 }

文档

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

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>;<。
推荐度:
标签: 全屏 解决 播放器
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top