欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

  發(fā)布時間:2012-12-24 15:15:16   作者:佚名   我要評論
有關于使用inline-block來代替float的討論也蠻多的,最常說的就是使用inline-block來代替float進行布局,或者使用inline-block來實現(xiàn)元素的居中效果;那么今天我們就一起來說說這個“4px”的問題,需要了解的朋友可以參考下

有關于使用inline-block來代替float的討論也蠻多的,最常說的就是使用inline-block來代替float進行布局,或者使用inline-block來實現(xiàn)元素的居中效果。前面《CSS3制作的分頁導航》一文中就是使用的inline-block制作的居中效果,不過留下了一上問題,就是使用inline-block的元素之間會存在“4px”的空白間距。那么今天我們就一起來說說這個“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)像只有在這幾種瀏覽器中才會出現(xiàn)。下面我們就來說說解決這個“4px”(Chrome下是8px)的幾種方法:

方法一:改變HTML結構

簡單一點的方法就是就是改變HTML的結構,你可以使用下面幾種方法的任何一種都可以達到效果:

結構一:

復制代碼
代碼如下:

<ul>
<li>
item1</li><li>
item2</li><li>
item3</li><li>
item4</li><li>
item5</li>
</ul>

這種方法接近標簽換行格式的寫法,也更趨近閱讀。

結構二:

復制代碼
代碼如下:

<ul>
<li>item1</li
><li>item2</li
><li>item3</li
><li>item4</li
><li>item5</li>
</ul>

結構二和結構一幾乎是一樣,結束標簽的“>”成了另一行的起始標簽。

結構三:

復制代碼
代碼如下:

<ul>
<li>item1</li><!--
--><li>item2</li><!--
--><li>item3</li><!--
--><li>item4</li><!--
--><li>item5</li>
</ul>

結構三的方法采用的是html的注釋的方法,這種方法我想大家不太常見,不過同樣能解決我們需要解決的問題。

結構四:

復制代碼
代碼如下:

<ul><li>item1</li><li>item2</li><li>item3</li><li>item4</li><li>item5</li></ul>

結構四,我想是大家常用來解決這樣的問題的方法吧,下面我們來看看按上述幾種方法寫的效果:

方法一所說的是通過標簽來解決,雖然問題是解決了,但可以說不能稱作是技巧。而且上面的方法只適合于寫靜態(tài)頁面的時候,一旦你的HTML不是自己寫,而是后臺生成,就比如CMS來說,標簽后臺生成,此時,我想大家又要罵街了,這可怎么辦?其實我們除了上面的方法,還可以使用CSS來解決的。

方法二:負的margin

很多地方討論使用負的margin來解決,比如說:

復制代碼
代碼如下:

ul {
font-size: 12px;
}
ul li {
margin-right: -4px;
*margin-right: 0;
}

這種解決方法并不完美,如果你的父元素設置的字號不一樣,可能你的“-4px”就不能解決問題。況且在Chrome中你需要另外設置一個負的margin值才能實現(xiàn)同等的效果。

當然有些文章介紹使用"-0.25em"來解決,這也是跟元素的字號有極大的關系。所以我個人建議不使用負的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”元素丟失關閉標簽

復制代碼
代碼如下:

<ul>
<li>item1
<li>item2
<li>item3
<li>item4
<li>item5
</ul>

樣式基本不變,我們來看看效果:

這種方法雖然能達到各瀏覽器的兼容,但還是有一個前提,那就是“DOCTYPE”要選擇對,在“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”的值,從而實現(xiàn)我們需要的效果。

上面講述了多種方法,但要兼容多個瀏覽器版本,并不每種方法實用,以前常用的方法,這次測試并不兼容所有瀏覽器。要做到兼容所有瀏覽器,個人認為還是在html的標簽上做一定的處理,或者采用最后一種方法,通過“jQuery”來改變“nodeType”值達到效果。針對這個“inline-block”之間的間距有幾篇文章做過介紹,但里面的方法,和上面介紹的測試的基本一樣,具體如何運用,大家還是根據(jù)自己的需求進行選擇或處理。
那么有關于“inline-block”的間距如何去除,今天就扯到這了,希望這篇文章對喜歡用inline-block的童鞋有所幫助。如果您有更好的方法,記得與我們一起分享,歡迎在下面的評論中留下您的經(jīng)驗,或者指正上面的不對之處。

更新:全兼容的樣式解決方法

經(jīng)過高人指點,使用純CSS還是找到了兼容的方法,就是在父元素中設置font-size:0,用來兼容chrome,而使用letter-space:-N px來兼容safari:

復制代碼
代碼如下:

.finally-solve {
letter-spacing: -4px;/*根據(jù)不同字體字號或許需要做一定的調(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;
}

相關文章

  • 前端CSS Grid 布局示例詳解

    CSS Grid 是一種二維布局系統(tǒng),可以同時控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復雜模塊結構中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋
    2025-04-16
  • CSS Padding 和 Margin 區(qū)別全解析

    CSS 中的 padding 和 margin 是兩個非?;A且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細介紹 padding 和 margin 的概念、區(qū)別以及如何在實際項目中使用它們
    2025-04-07
  • CSS will-change 屬性示例詳解

    will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧
    2025-04-07
  • CSS去除a標簽的下劃線的幾種方法

    本文給大家分享在 CSS 中,去除a標簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2025-04-07
  • 前端高級CSS用法示例詳解

    在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實現(xiàn)復雜交互和動態(tài)效果的關鍵技術之一,隨著前端技術的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將
    2025-04-07
  • css中的 vertical-align與line-height作用詳解

    文章詳細介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧
    2025-03-26
  • 淺析CSS 中z - index屬性的作用及在什么情況下會失效

    z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用
    2025-03-21
  • CSS @media print 使用詳解

    文章詳細介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁控制、調(diào)整邊距和背景等
    2025-03-18
  • CSS模擬 html 的 title 屬性(鼠標懸浮顯示提示文字效果)

    本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標懸浮顯示提示文字效果,通過設置`.tipBox`和`.tipBox.tipContent`的樣式,實現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起
    2025-03-10
  • 前端 CSS 動態(tài)設置樣式::class、:style 等技巧(推薦)

    本文介紹了Vue.js中動態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對象語法和數(shù)組語法,通過對象語法,可以根據(jù)條件動態(tài)切換類名或樣式;通過數(shù)組語法,可以同時綁定多個類名或樣式,此外
    2025-02-26

最新評論