去掉HTML中Inline-Block的空白的方法


本文摘自PHP中文网,作者不言,侵删。

这篇文章主要为大家详细介绍了快速去掉HTML中Inline-Block空白的5种方法,感兴趣的小伙伴们可以参考一下

当需要在”inline”元素上控制margin和padding时,inline-block属性值变得非常有用,有了它,你不在需要让这些元素去“block”和“float”。但有一个问题,当使用inline-block时,HTML元素之间的空白会显示在页面上。很讨厌。有几种方法可以除去这些空白;其中一个非常巧妙。

方法1:各元素间不留任何空白

一个100%能解决这个问题的方法是在你的HTML代码里元素间不留任何空白:

1

2

3

4

5

<ul>  

<li>Item content</li>  

<li>Item content</li>  

<li>Item content</li>  

</ul>

当然,这样看起来很乱,让代码不好维护,但很实用,很直观,更重要的……很可靠。

方法2:在父元素上设置font-size: 0

解决这个空白问题最好的方案是在这些inline-block元素的父元素上设置font-size: 0。如果你的<UL>里有inline-block的<LI>,那你可以这样做:

1

2

3

4

5

6

.inline-block-list { /* ul or ol with this class */  

 font-size: 0;  

}  

.inline-block-list li {  

 font-size: 14px; /* put the font-size back */  

}

为了不让父元素的字体大小影响子元素,你需要重新在子元素上设置font-size值,这通常很简单。唯一可能遇到麻烦的情况是你用相对大小设置字体。但大多数时候,这样的方法能解决你的问题。

方法3:HTML注释

这种方法有点暴力,但同样能奏效。将HTML元素间用注释填充,这跟它们之间没有空白效果一样:

1

2

3

4

5

<ul>

 <li>Item content</li><!--

 --><li>Item content</li><!--

 --><li>Item content</li>

</ul>

用一个词…恶心。用两个词…非常恶心。用三个词….OK,你明白。但这确实管用!

方法4:负边距

跟方法2很相似,抱歉。你可以利用inline-block的灵活性,给它们设置一个负边距,隐藏空白:

1

2

3

.inline-block-list li {  

 margin-left: -4px;  

}

这种方法最不推荐,因为你必须考虑到各种情况,有时候会出现一些无法预料的空白。最好不用这招。

方法5:首尾接龙

另外一个利用HTML标记的方法是将元素的闭合标记和下一个元素的开始标记靠在一起:

1

2

3

4

5

<ul>

 <li>Item content</li

 ><li>Item content</li

 ><li>Item content</li>

</ul>

并不像HTML注释那样丑陋,但我宁愿手工删除那些空白,而不考虑代码的可读性。

没有一个方法是非常理想的,但在网页中不留空白也是一个烂方法。这并不是在警告你不要使用inline-block,inline-block仍然是非常的有用,只是在使用你要明白如何处理里面出现的空白。

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

相关推荐:

Express使用html模板的代码分析

以上就是去掉HTML中Inline-Block的空白的方法的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

去掉html中Inline-Block的空白的方法

如何去除css的Inline-Block换行引起的间隙

详解json_decode出现空白的解决方法

html页面底部多出很多空白部分是什么原因

css怎么清除空白

css中Inline-Block什么意思

更多相关阅读请进入《Inline-Block》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...