css - 为什么video不能填满整个父级div?底部有黑边?
问题描述
代码如下:
<!DOCTYPE html> <html> <head> <title>Demo</title> <style>.videoContainer { width: 70%; height: auto; background: #000;}</style></head> <body> <p > <video controls preload='auto' > <source src='https://www.haobala.com/wenda/test.mp4' type='video/mp4' /> <p>Your browser does not support the video tag.</p> </video></p></body> </html>
最终的显示效果:

我的疑惑是:为什么父元素p会比video高出几个像素,从而导致底部有黑边?
问题解答
回答1:补充下,貌似这个黑边是因为父元素样式里有了background属性,具体来说是background-color这个属性,至于成因是什么,实话讲我也不知道……
目前猜测原因可能是和video默认的display是inline有关系。
所以解决方案应该是:
加上font-size: 0;;
去掉background/background-color属性;
给<video>加上display: block;样式。
回答2:因为你的父元素videoContainer没有高度,当<video>使用了contorl属性的时候,就会出现一个黑边。**解决方法:1、删掉contorl属性 2、给父元素高度,或者用padding撑开等**
回答3:其实这是一个html的bug,父级的font size设为0就正常了。。
相关文章:
1. 垃圾回收 - java 如何手动回收对象2. dockerfile - 为什么docker容器启动不了?3. android - WebView加载天猫等购物网页出问题?4. nignx - docker内nginx 80端口被占用5. 利用css3 translate来代替传统的修改left和top实现动画,触发webkit的GPU加速渲染功能实现流畅的动画效果6. mysql字段保存的字符串含有隐藏字符如何清除7. docker-compose 为何找不到配置文件?8. boot2docker无法启动9. mysql - 请问有innodb 引擎的表导入900w 的数据,用了快9个小时。有什么快速的方法吗。正常是多少小时一般。10. angular.js - angular ui bootstrap 中文显示问题

网公网安备