【BUG】移动端元素间出现间隔
问题:
列表有个吸顶,在移动端上发现表现的很奇怪,有一条缝。
data:image/s3,"s3://crabby-images/7139d/7139d5e77020d3a1c4e4e3dfb130620e5e48f5b2" alt=""
过程
在chrome中查看filter-mask
和filter-container
发现这两个盒模型是一致的
data:image/s3,"s3://crabby-images/a9a02/a9a02c1de784d5f45e30e7bace0fcc37e19dedf2" alt=""
data:image/s3,"s3://crabby-images/cdfe1/cdfe107bbdd4ce2dddee6f8838504e6c711e4dc7" alt=""
但是在手机中查看却大大不同
data:image/s3,"s3://crabby-images/0f8fc/0f8fc12413a329c60375ddeed7ecbf1a94258ae8" alt=""
data:image/s3,"s3://crabby-images/122e1/122e10c0635e23ec769e57a580d0687dc1ba3fd8" alt=""
可以看到移动端上filter-mask
和filter-container
缺了一块,这就是导致bug的原因;
看一下这的dom以及css,当filter-mask
需要吸顶是会添加tab-fixed
类.
data:image/s3,"s3://crabby-images/79560/7956056a015b2e33daa09ba4e383f51efe8c04fd" alt=""
<div id="filter-mask"class="filter-mask">
<div class="filter-container">
// ... 一些下拉筛选的内容
</div>
</div>
<style type="text/css">
.filter-mask{
width: 100%;
}
.tab-fixed{
position: fixed;
top:0;
z-index:99;
}
.filter-container{
width: 100%;
display: inline-block;
font-size: 28px;
}
</style>
经过排查确定高度的差异不是由于filter-container
内容物导致的,所以排查点聚焦到了filter-mask
和filter-container
自身上;
可以看到filter-mask
被撑大了,这种奇怪的空隙让我联想到之前ul li标签写模板是出现的空隙,接下来尝试下 给父级filter-mask
设置font-size:0
, 之后查看发现显示恢复正常,filter-mask
和filter-container
宽高一致; 和在chrome上看到的效果一致;
此时基本上就很接近真理了,我们将dom做下修改
<div id="filter-mask"class="filter-mask"><div class="filter-container">
// ... 一些下拉筛选的内容
</div>
</div>
没看错,只是将两个dom间的格式化抛弃,之后在手机上查看效果,发现展示恢复正常。
结论
此次问题是由于代码自动格式化的时候,往往有一些缩进、换行,当元素的display
为inline
或者inline-block
时,这些缩进、换行就会产生空白,导致问题。
所以以下的方法均使用修复此次问题:
- 使dom紧贴着没有格式化(不推荐)
- 将子集
filter-container
的display: inline-block;
移除 (视情况而定,在此情景下可移除);
- 将子集
- 给子集级
filter-mask
设置float:left/right
(不太推荐,浮动可能会有影响);
- 给子集级
- 将父级
filter-mask
设置font-size:0
;(推荐,影响最小,子集记得重新设置font-size)
- 将父级
====以上====
贴个相关文章 : https://⭐️ css-tricks.⭐️ com/fighting-⭐️ the-space-between-inline-block-elements/ (去掉⭐️ )
像这篇文章说的
This isn’t a “bug” (I don’t think). It’s just the way setting elements on a line works.
确实有其合理性,根据需求去处理就阔以啦