css - 关于table里面元素有display:inline-block的一些疑惑
问题描述
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Document</title> <style>body{font-size:14px;}.block{width:100%;background-color:red;}.a{display: table;width:100%;height:100%;}.b{display: table-cell;vertical-align: middle;}.c{display:inline-block;background-color:yellow;width:100px;height:8px;} </style></head><body> <p class='block'><p class='a'> <p class='b'><p class='c'></p> </p></p> </p></body></html>
如上代码,有两个问题想请问一下:1.当.c的height为0的时候,为什么.b会有14的高度?2.当.c的height不为0的时候,为什么距底边有间隙?
问题解答
回答1:font-size的原因, .c高度为0时, 将.b的font-size也设置成0
inline和inline-block都会有这个问题, 可能的原因是这两个属性, 会将前后的空格,或者解析成字符, 解决方法, 将.b的font-size设置成0, 或者将.c的inline-block属性换成block属性
回答2:.c{display:inline-block;background-color:yellow;width:100px;height:0;}
是这样啊,c的高度为0时,b的高度为16,没你说的14啊?谷歌测试
相关文章:
1. html - 爬虫时出现“DNS lookup failed”,打开网页却没问题,这是什么情况?2. javascript - echart+百度地图3. web - Rails3使用form_for时出现undefined method `*_path’错误。4. css - autoprefixer没有添加web-kit前缀5. 无效的配置对象已使用与API模式不匹配的配置对象初始化了Webpack6. javascript 开发百度地图7. nginx - 关于vue项目部署到ngnix后出现的问题8. angular.js - 百度爬虫如何处理“#”符号?9. nosql - mongodb 多组数据不固定字段查询问题 [百度党请绕道]10. css3 - 请问,如何通过CSS实现高度height随宽度width变化而变化,保持长宽比例不变,宽度是根据父元素宽度变化的?
