• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > 如何解决layer弹出层中H5播放器全屏出错

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

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含layer,全屏,h5播放器全屏,layer,播放器等相关知识,匿名希望在学习及工作中可以帮助到您
本文主要介绍了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的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; 
 }

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

相关推荐:

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

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

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

您可能想查找下面的文章:

  • 如何解决layer弹出层中H5播放器全屏出错
  • 详解HTML5网络拓扑图整合OpenLayers实现GIS地图应用(图)
  • 中国首届CSS开发者大会的演讲PPT用什么快捷的框架做的?

相关文章

  • 2018-12-03HTML5第二天笔记
  • 2018-12-03phonegap创建联系人详解
  • 2018-12-03hwSlider-内容滑动切换效果(二):响应式可触控滑动
  • 2018-12-03通过H5实现拍照功能的实例详解
  • 2018-12-03浅谈HTML5的未来发展
  • 2018-12-03HTML5 之2__列表标记
  • 2018-12-0310个HTML5代码片段可在网站制作中随时可用详解
  • 2018-12-03html5 canvas 画图教程案例分析_html5教程技巧
  • 2018-12-03如何去设计一个自适应的网页设计或HTMl5
  • 2018-12-03phonegap获取设备信息方法详解

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • H5+C3做出优酷视频截图效果
    • 在html文件引入其它html文件的几种方法
    • H5移动端做一个不限个数的通栏按钮的示例代码详解
    • html5 meter标签是什么意思?html5 meter标签的用法及属性介绍
    • 分享移动端网页宽度值实例代码
    • HTML5 canvas实现中奖转盘的实例代码
    • 解析HTML5的存储功能和web SQL的相关操作方法_html5教程技巧
    • html5记忆翻牌游戏实现思路及代码_html5教程技巧
    • HTML5中垂直上下居中的解决方案
    • 分享一个video标签无法播放mp4的问题以及解决方案

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有