inline-block元素的4px空白間距解決方案

有關(guān)于使用inline-block來代替float的討論也蠻多的,最常說的就是使用inline-block來代替float進(jìn)行布局,或者使用inline-block來實(shí)現(xiàn)元素的居中效果。前面《CSS3制作的分頁導(dǎo)航》一文中就是使用的inline-block制作的居中效果,不過留下了一上問題,就是使用inline-block的元素之間會(huì)存在“4px”的空白間距。那么今天我們就一起來說說這個(gè)“4px”的問題。
HTML Markup
<ul>
<li>item1</li>
<li>item2</li>
<li>item3</li>
<li>item4</li>
<li>item5</li>
</ul>
CSS Code
*{
margin: 0;
padding: 0;
}
ul {
list-style: none outside none;
padding: 10px;
background: green;
text-align: center;
}
ul li {
display: inline-block;
*display: inline;
zoom: 1;
background: orange;
padding: 5px;
}
上面的demo效果,明顯的可以看出,在inline-block的元素之間存在“4px”的空白:
上面截圖是:IE8-9、Firefox、Safari等瀏覽器下的效果,換句話說,這種現(xiàn)像只有在這幾種瀏覽器中才會(huì)出現(xiàn)。下面我們就來說說解決這個(gè)“4px”(Chrome下是8px)的幾種方法:
方法一:改變HTML結(jié)構(gòu)簡單一點(diǎn)的方法就是就是改變HTML的結(jié)構(gòu),你可以使用下面幾種方法的任何一種都可以達(dá)到效果:
結(jié)構(gòu)一:
<ul>
<li>
item1</li><li>
item2</li><li>
item3</li><li>
item4</li><li>
item5</li>
</ul>
這種方法接近標(biāo)簽換行格式的寫法,也更趨近閱讀。
結(jié)構(gòu)二:
<ul>
<li>item1</li
><li>item2</li
><li>item3</li
><li>item4</li
><li>item5</li>
</ul>
結(jié)構(gòu)二和結(jié)構(gòu)一幾乎是一樣,結(jié)束標(biāo)簽的“>”成了另一行的起始標(biāo)簽。
結(jié)構(gòu)三:
<ul>
<li>item1</li><!--
--><li>item2</li><!--
--><li>item3</li><!--
--><li>item4</li><!--
--><li>item5</li>
</ul>
結(jié)構(gòu)三的方法采用的是html的注釋的方法,這種方法我想大家不太常見,不過同樣能解決我們需要解決的問題。
結(jié)構(gòu)四:
<ul><li>item1</li><li>item2</li><li>item3</li><li>item4</li><li>item5</li></ul>
結(jié)構(gòu)四,我想是大家常用來解決這樣的問題的方法吧,下面我們來看看按上述幾種方法寫的效果:
方法一所說的是通過標(biāo)簽來解決,雖然問題是解決了,但可以說不能稱作是技巧。而且上面的方法只適合于寫靜態(tài)頁面的時(shí)候,一旦你的HTML不是自己寫,而是后臺(tái)生成,就比如CMS來說,標(biāo)簽后臺(tái)生成,此時(shí),我想大家又要罵街了,這可怎么辦?其實(shí)我們除了上面的方法,還可以使用CSS來解決的。
方法二:負(fù)的margin很多地方討論使用負(fù)的margin來解決,比如說:
ul {
font-size: 12px;
}
ul li {
margin-right: -4px;
*margin-right: 0;
}
這種解決方法并不完美,如果你的父元素設(shè)置的字號(hào)不一樣,可能你的“-4px”就不能解決問題。況且在Chrome中你需要另外設(shè)置一個(gè)負(fù)的margin值才能實(shí)現(xiàn)同等的效果。
當(dāng)然有些文章介紹使用"-0.25em"來解決,這也是跟元素的字號(hào)有極大的關(guān)系。所以我個(gè)人建議不使用負(fù)的margin來解決這樣的問題。
方法三:設(shè)置父元素字體為0第三種方法設(shè)置父元素的字體為“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等瀏覽器下是達(dá)到了效果,可是在Safari下可問題依然存在:
按此來說,方法三也不是絕佳的好方法,用不用大家自己考慮。
方法四:丟失結(jié)束標(biāo)簽說實(shí)在的,這種方法又回到了方法一,在html標(biāo)簽上動(dòng)手腳。就是讓“inline-block”元素丟失關(guān)閉標(biāo)簽
<ul>
<li>item1
<li>item2
<li>item3
<li>item4
<li>item5
</ul>
樣式基本不變,我們來看看效果:
這種方法雖然能達(dá)到各瀏覽器的兼容,但還是有一個(gè)前提,那就是“DOCTYPE”要選擇對(duì),在“XHTML”下可就問題又出來了。
方法五:jquery方法最后在給大家提供一種jquery的方法:
HTML Markup
<ul class="removeTextNodes" >
<li>item1</li>
<li>item2</li>
<li>item3</li>
<li>item4</li>
<li>item5</li>
</ul>
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();
最后一種方法是通過jQuery來改變“nodeType”的值,從而實(shí)現(xiàn)我們需要的效果。
上面講述了多種方法,但要兼容多個(gè)瀏覽器版本,并不每種方法實(shí)用,以前常用的方法,這次測(cè)試并不兼容所有瀏覽器。要做到兼容所有瀏覽器,個(gè)人認(rèn)為還是在html的標(biāo)簽上做一定的處理,或者采用最后一種方法,通過“jQuery”來改變“nodeType”值達(dá)到效果。針對(duì)這個(gè)“inline-block”之間的間距有幾篇文章做過介紹,但里面的方法,和上面介紹的測(cè)試的基本一樣,具體如何運(yùn)用,大家還是根據(jù)自己的需求進(jìn)行選擇或處理。
那么有關(guān)于“inline-block”的間距如何去除,今天就扯到這了,希望這篇文章對(duì)喜歡用inline-block的童鞋有所幫助。如果您有更好的方法,記得與我們一起分享,歡迎在下面的評(píng)論中留下您的經(jīng)驗(yàn),或者指正上面的不對(duì)之處。
更新:全兼容的樣式解決方法
經(jīng)過高人指點(diǎn),使用純CSS還是找到了兼容的方法,就是在父元素中設(shè)置font-size:0,用來兼容chrome,而使用letter-space:-N px來兼容safari:
.finally-solve {
letter-spacing: -4px;/*根據(jù)不同字體字號(hào)或許需要做一定的調(diào)整*/
word-spacing: -4px;
font-size: 0;
}
.finally-solve li {
font-size: 16px;
letter-spacing: normal;
word-spacing: normal;
display:inline-block;
*display: inline;
zoom:1;
}
相關(guān)文章
- CSS Grid 是一種二維布局系統(tǒng),可以同時(shí)控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋2025-04-16
CSS Padding 和 Margin 區(qū)別全解析
CSS 中的 padding 和 margin 是兩個(gè)非常基礎(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實(shí)際項(xiàng)目中使用它們2025-04-07- will-change 是一個(gè) CSS 屬性,用于告訴瀏覽器某個(gè)元素在未來可能會(huì)發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧2025-04-07
- 本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-04-07
- 在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實(shí)現(xiàn)復(fù)雜交互和動(dòng)態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級(jí),本文將2025-04-07
css中的 vertical-align與line-height作用詳解
文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場(chǎng)景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧2025-03-26淺析CSS 中z - index屬性的作用及在什么情況下會(huì)失效
z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用2025-03-21- 文章詳細(xì)介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場(chǎng)景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁控制、調(diào)整邊距和背景等2025-03-18
CSS模擬 html 的 title 屬性(鼠標(biāo)懸浮顯示提示文字效果)
本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標(biāo)懸浮顯示提示文字效果,通過設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實(shí)現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起2025-03-10前端 CSS 動(dòng)態(tài)設(shè)置樣式::class、:style 等技巧(推薦)
本文介紹了Vue.js中動(dòng)態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對(duì)象語法和數(shù)組語法,通過對(duì)象語法,可以根據(jù)條件動(dòng)態(tài)切換類名或樣式;通過數(shù)組語法,可以同時(shí)綁定多個(gè)類名或樣式,此外2025-02-26