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

淺談inline-block及解決空白間距

  發(fā)布時間:2013-03-28 16:05:59   作者:佚名   我要評論
inline-block 屬性的使用隨處可見,ie 從 5.5 開始就已經(jīng)支持 display:inline-block 了,只是支持的并不是那么完美,接下來為大家詳細介紹下空白間隙是如何產(chǎn)生的,以及解決辦法,感興趣的朋友可以參考下哈

去掉display:inline-block元素間的多余空白

如下一段代碼,display:inline-block元素間的多余空白:

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">  
  2. *{margin:0; padding:0;}   
  3. body{font:12px/20px Tahoma, Geneva, sans-serif; padding:200px;}   
  4. img {border:0;}   
  5. ul li{ list-style:none;}   
  6.   
  7. .test{width:200px; border:1px blue solid;}   
  8. .test a{width:32px; height:32px; display:inline-block; text-indent:-9999em; *text-indent:0; *line-height:0; *font-size:0; background:blue;} /* *號部分解決IE7 無法顯示 display:inline-block 元素里面的內(nèi)容,博客內(nèi)有文章介紹 */   
  9. </style>  
  10. <div class="test">  
  11.     <a href="#"></a>  
  12.     <a href="#"></a>  
  13.     <a href="#"></a>  
  14.     <a href="#"></a>  
  15.     <a href="#"></a>  
  16. </div>  

運行截圖:



會發(fā)現(xiàn) 每1個帶display:inline-block;屬性的鏈接 a 水平、垂直方向都帶有一定的空白

解決方法:

方法1(附注釋說明):

CSS Code復(fù)制內(nèi)容到剪貼板
  1. .test{width:200pxborder:1px blue solidfont-size:0;}      
  2. .test a{width:32pxheight:32pxdisplay:inline-blocktext-indent:-9999em; *text-indent:0; *line-height:0; *font-size:0; background:bluevertical-align:top;} /* *號部分解決IE7 無法顯示 display:inline-block 元素里面的內(nèi)容,博客內(nèi)有文章介紹 */     
  3. /* display:inline-block元素的父元素定義 font-size:0 ,可去掉元素水平4px的空白,子元素若要顯示文字可重新定義font-size屬性即可 */     
  4. /* display:inline-block元素本身定義 vertical-align 屬性可去掉元素垂直方向的多余空白*/    


關(guān)鍵在于父元素定義font-size:0 去掉行內(nèi)塊元素水平方向空白;子元素定義vertical-align 屬性去掉行內(nèi)塊元素垂直方向空白!
如果標簽a內(nèi)加上任意文字,則display:inline-block元素不會生成垂直方向有空白!

方法2(附注釋說明):

通過設(shè)置父元素 letter-spacing來解決的,該屬性的值同字體有關(guān): 如:.test{letter-spacing:-.25em} 要注意的是-.25em是字體設(shè)置為Arial時的情況,為其他字體時會有些不同,下面僅列出了常用的幾個, 常用字體與letter-spacing的關(guān)系:



復(fù)制代碼
代碼如下:

宋體/Verdana -.5em
Arial -.25em
Tahoma -.333em


方法2未經(jīng)實驗,備忘!

如今有很多網(wǎng)站都用上了 inline-block 屬性,比如 {display:inline-block; *display:inline; *zoom:1},以上 css 代碼隨處可見。很多人看見 *display:inline; *zoom:1 就下意識的認為:哦,原來 inline-block 這個屬性 ie6 和 ie7 不支持。那么 ie6,7 真的不支持 display:inline-block 嗎?

事實上,ie 從 5.5 開始就已經(jīng)支持 display:inline-block 了,只是支持的并不是那么完美。具體的請閱讀淘寶UED官方博客——一絲所寫的《display:inline-block 前世今生》。

當我們使用 inline-block 的時候,就會產(chǎn)生“空白間隙”問題。代碼如下:

復(fù)制代碼
代碼如下:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8"/>
<title>inline-block</title>
<link rel="stylesheet" type="text/css" href="css/base.css" media="all"/>
<style type="text/css">
li{
display:inline-block;
*display:inline;
*zoom:1;
}
</style>
</head>
<body>
<ul>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
</ul>
</body>
</html>

效果圖如下:

我們可以看到:在 ie8、chrome、firefox、opera 以及 safari 瀏覽器下,兩張圖片之間有“空白間隙”。

但是在 ie6 和 ie7 瀏覽器下卻正常顯示,效果如下:

下面我們就來說說這個“空白間隙”是如何產(chǎn)生的,以及解決辦法。

先來說說“空白間隙”是怎么產(chǎn)生的?先看下源代碼:

復(fù)制代碼
代碼如下:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8"/>
<title>inline-block</title>
<link rel="stylesheet" type="text/css" href="css/base.css" media="all"/>
<style type="text/css">
li{
display:inline-block;
*display:inline;
*zoom:1;
}
</style>
</head>
<body>
<ul>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
</ul>
</body>
</html>

從上面的代碼我們很難發(fā)現(xiàn)產(chǎn)生“空白間隙”的問題。其實這個問題是我們寫代碼的習(xí)慣所造成的。平時我們寫代碼,為了使代碼看上去“層級分明”,通常會在標簽結(jié)束符后順手打個回車,而回車會產(chǎn)生回車符,回車符相當于空白符,通常情況下,多個連續(xù)的空白符會合并成一個空白符,而產(chǎn)生“空白間隙”的真正原因就是這個讓我們并不怎么注意的空白符。

既然我們已經(jīng)知道產(chǎn)生問題的原因了,那么就很好解決該問題。空白符也是字符,只要是字符就會聯(lián)想到字體,字體大小之類的。所以去除空白符的存在只需要設(shè)置字體大小為零就行了(font-size:0;)。修改已上代碼:

復(fù)制代碼
代碼如下:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8"/>
<title>inline-block</title>
<link rel="stylesheet" type="text/css" href="css/base.css" media="all"/>
<style type="text/css">
ul{
font-size:0;
}
li{
display:inline-block;
*display:inline;
*zoom:1;
}
</style>
</head>
<body>
<ul>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
</ul>
</body>
</html>

可以看到在 ie8,firefox,chrome 和 opera 瀏覽器下已經(jīng)沒有問題了,但是在 safari 瀏覽器下還是有問題。

關(guān)于 safari 瀏覽器的兼容,請閱讀大漠寫的《如何解決inline-block元素的空白間距》。

最后整理:

復(fù)制代碼
代碼如下:

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8"/>
<title>inline-block</title>
<link rel="stylesheet" type="text/css" href="css/base.css" media="all"/>
<style type="text/css">
ul{
font-size:0;
letter-spacing: -8px;/*根據(jù)不同字體字號或許需要做一定的調(diào)整*/
word-spacing: -8px;
}
li{
display:inline-block;
*display:inline;
*zoom:1;
letter-spacing:normal;
word-spacing:normal;
}
</style>
</head>
<body>
<ul>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
<li><img src="images/cat.jpg" alt="" width="248" height="162"/></li>
</ul>
</body>
</html>

測試瀏覽器:ie6,ie7,ie8,chrome,firefox,safari,opera。

相關(guān)文章

  • 前端CSS Grid 布局示例詳解

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

    CSS 中的 padding 和 margin 是兩個非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(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)復(fù)雜交互和動態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(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屬性,通過鼠標懸浮顯示提示文字效果,通過設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起
    2025-03-10
  • 前端 CSS 動態(tài)設(shè)置樣式::class、:style 等技巧(推薦)

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

最新評論