span有间隔_这几个span之间为什么会有空隙呢?

解决inline-block元素的空白间距

方法一:改变HTML结构

简单一点的方法就是就是改变HTML的结构,你可以使用下面几种方法的任何一种都可以达到效果:

结构一

  • item1

  • item2

  • item3

  • item4

  • item5

这种方法接近标签换行格式的写法,也更趋近阅读。

结构二

  • item1

>

item2

>

item3

>

item4

>

item5

结构二和结构一几乎是一样,结束标签的“>”成了另一行的起始标签。

结构三:

  • item1
  • item2
  • item3
  • item4
  • item5

结构三的方法采用的是html的注释的方法,这种方法我想大家不太常见,不过同样能解决我们需要解决的问题。

结构四:

  • item1
  • item2
  • item3
  • item4
  • item5

方法一所说的是通过标签来解决,虽然问题是解决了,但可以说不能称作是技巧。而且上面的方法只适合于写静态页面的时候,一旦你的HTML不是自己写,而是后台生成,就比如CMS来说,标签后台生成,此时,我想大家又要骂街了,这可怎么办?其实我们除了上面的方法,还可以使用CSS来解决的。

方法二:负的margin

ul {

font-size: 12px;

}

ul li {

margin-right: -4px;

*margin-right: 0;

}

这种解决方法并不完美,如果你的父元素设置的字号不一样,可能你的“-4px”就不能解决问题。况且在Chrome中你需要另外设置一个负的margin值才能实现同等的效果。

方法三:设置父元素字体为0

第三种方法设置父元素的字体为“0”,然后在“inline-block”元素上重置字体需要的大小。

ul {

list-style: none outside none;

padding: 10px;

background: green;

text-align: center;

font-size: 0px;

}

ul li {

display: inline-block;

*display: inline;

zoom: 1;

background: orange;

padding: 5px;

font-size: 12px;

}

这样处理在Firexfox,chrome等浏览器下是达到了效果,可是在Safari下可问题依然存在。

方法四:丢失结束标签

说实在的,这种方法又回到了方法一,在html标签上动手脚。就是让“inline-block”元素丢失关闭标签

  • item1
  • item2
  • item3
  • item4
  • item5

这种方法虽然能达到各浏览器的兼容,但还是有一个前提,那就是“DOCTYPE”要选择对,在“XHTML”下可就问题又出来了。

方法五:jquery方法

HTML Markup

  • item1
  • item2
  • item3
  • item4
  • item5

CSS Code

ul {

list-style: none outside none;

padding: 10px;

background: green;

text-align: center;

font-size: 12px;

}

ul li {

display: inline-block;

*display: inline;

zoom: 1;

background: orange;

padding: 5px;

}

jQuery Code

$('.removeTextNodes').contents().filter(function() {

return this.nodeType === 3;

}).remove();

上面讲述了多种方法,但要兼容多个浏览器版本,并不每种方法实用,以前常用的方法,这次测试并不兼容所有浏览器。要做到兼容所有浏览器,个人认为还是在html的标签上做一定的处理,或者采用最后一种方法,通过“jQuery”来改变“nodeType”值达到效果。针对这个“inline-block”之间的间距有几篇文章做过介绍,但里面的方法,和上面介绍的测试的基本一样,具体如何运用,大家还是根据自己的需求进行选择或处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值