0%

解决相邻inline-block之间的间隔

转载自 zhangxinxu from http://www.zhangxinxu.com

一、现象描述

真正意义上的inline-block水平呈现的元素间,换行显示或空格分隔的情况下会有间距.

我们使用CSS更改非inline-block水平元素为inline-block水平,也会有该问题:

1
2
3
4
5
space a {
display: inline-block;
padding: .5em 1em;
background-color: #cad5eb;
}
1
2
3
4
5
<div class="space">
<a href="##">惆怅</a>
<a href="##">淡定</a>
<a href="##">热血</a>
</div>

这种表现是符合规范的应该有的表现。

元素被当成行内元素排版的时候,元素之间的空白符(空格、回车换行等)都会被浏览器处理,根据white-space的处理方式(默认是normal,合并多余空白),原来HTML代码中的回车换行被转成一个空白符,在字体不为0的情况下,空白符占据一定宽度,所以inline-block的元素之间就出现了空隙。这些元素之间的间距会随着字体的大小而变化,当行内元素font-size:16px时,间距为8px。

二、方法之移除空格

元素间留白间距出现的原因就是标签段之间的空格,因此,去掉HTML中的空格,自然间距就木有了。考虑到代码可读性,显然连成一行的写法是不可取的,我们可以:

1
2
3
4
5
<div class="space">
<a href="##">惆怅</a
><a href="##">淡定</a
><a href="##">热血</a>
</div>
1
2
3
4
5
<div class="space">
<a href="##">惆怅</a><!--
--><a href="##">淡定</a><!--
--><a href="##">热血</a>
</div>

使用margin负值

1
2
3
4
1.space a {
2 display: inline-block;
3 margin-right: -3px;
4}

margin负值的大小与上下文的字体和文字大小相关

使用font-size:0

类似下面的代码:

1
2
3
4
5
6
1.space {
2 font-size: 0;
3}
4.space a {
5 font-size: 12px;
6}

这个方法,基本上可以解决大部分浏览器下inline-block元素之间的间距(IE7等浏览器有时候会有1像素的间距)。

使用letter-spacing

类似下面的代码:

1
2
3
4
5
6
1.space {
2 letter-spacing: -3px;
3}
4.space a {
5 letter-spacing: 0;
6}

使用word-spacing

类似下面代码:

1
2
3
4
5
6
1.space {
2 word-spacing: -6px;
3}
4.space a {
5 word-spacing: 0;
6}

一个是字符间距(letter-spacing)一个是单词间距(word-spacing),大同小异。据我测试,word-spacing的负值只要大到一定程度,其兼容性上的差异就可以被忽略。因为,貌似,word-spacing即使负值很大,也不会发生重叠。

与上面demo一样的效果,这里就不截图展示了。如果您使用Chrome浏览器,可能看到的是间距依旧存在。确实是有该问题,原因我是不清楚,不过我知道,可以添加display: table;display:inline-table;让Chrome浏览器也变得乖巧。

1
2
3
4
1.space {
2 display: inline-table;
3 word-spacing: -6px;
4}