目錄
關於inline-block可能很多人都不熟悉,佈局這方面很多人用的都是flex或者浮動,flex很強大毋庸置疑的可是關於兼容性就不是很讓人滿意,而浮動雖然很兼容可是覺得清除浮動就很麻煩,於此我在一些大型網站,例如我們的segmentfault的首頁導航展示用的佈局就是inline-block,覺得inline-block可以擼一波,可是突然發現這裡面也存在一些小問題,首先先po出程式碼
p之間的間距解決的方法
給父p加這樣的css屬性
webkit核心的瀏覽器(chrome)中,當css中定義的中文font-size小於12px的時候,瀏覽器仍然使用12px,這時就可以用-webkit-text-size -adjust:none;
首頁 web前端 css教學 關於Css3的inline-block遇到的坑

關於Css3的inline-block遇到的坑

Feb 02, 2018 pm 02:08 PM
css3 inline-block

關於inline-block可能很多人都不熟悉,佈局這方面很多人用的都是flex或者浮動,flex很強大毋庸置疑的可是關於兼容性就不是很讓人滿意,而浮動雖然很兼容可是覺得清除浮動就很麻煩,於此我在一些大型網站,例如我們的segmentfault的首頁導航展示用的佈局就是inline-block,覺得inline-block可以擼一波,可是突然發現這裡面也存在一些小問題,首先先po出程式碼

<p style="background-color:green">
      <p style="width:40px;height:30px;background-color:red;">

      </p>
      <p style="width:40px;height:30px;background-color:red;">

      </p>
      <p style="width:40px;height:30px;background-color:red;">

      </p>
</p>
登入後複製

關於Css3的inline-block遇到的坑
這時候我們採取inline-block進行佈局,神奇的事情就發生了

<p style="background-color:green;">
      <p style="width:40px;height:30px;background-color:red;display:inline-block;">

        </p>
      <p style="width:40px;height:30px;background-color:red;display:inline-block;">

        </p>
      <p style="width:40px;height:30px;background-color:red;display:inline-block;">

        </p>
    </p>
登入後複製

關於Css3的inline-block遇到的坑

#原本的3個p並排在一起,因為3個p變成了行內元素,所以也應該並排在一起,但是....
這裡出現了兩個問題:

  1. p之間出現間隔關於Css3的inline-block遇到的坑

  2. 子p與父p之間有一個4px的間距關於Css3的inline-block遇到的坑

這裡會出現這種問題的原因是因為inline-block水平呈現的元素間,換行顯示或空格分隔的情況下會有間距

p之間的間距解決的方法

在這裡我嘗試過一個方法就是設定margin-right為負值,

<p style="background-color:green">
      <p style="width:40px;height:30px;background-color:red;display:inline-block;margin-bottom:-4px;margin-right:-4px">

      </p>
      <p style="width:40px;height:30px;background-color:red;display:inline-block;margin-bottom:-4px;margin-right:-4px">

      </p>
      <p style="width:40px;height:30px;background-color:red;display:inline-block;margin-bottom:-4px;margin-right:-4px">

      </p>
    </p>
登入後複製

關於Css3的inline-block遇到的坑

在這裡我們能看到第一個p與第二個p仍然有一個1px的間距,而第二個和第三個沒有間距,子p和父p沒有間距,說明我們的問題不是在這裡

我在參考張旭鑫大神的博客深感佩服覺得採用這種方法最好:

給父p加這樣的css屬性

font-size:0
-webkit-text-size-adjust:none;
登入後複製

po出程式碼

<p style="background-color:green;font-size:0;-webkit-text-size-adjust:none;">

        <p style="width:40px;height:30px;background-color:red;display:inline-block;">

        </p>

        <p style="width:40px;height:30px;background-color:red;display:inline-block;">

        </p>

        <p style="width:40px;height:30px;background-color:red;display:inline-block;">

        </p>
登入後複製

關於Css3的inline-block遇到的坑

#那麼又有一個問題了,-webkit-text-size-adjust是什麼?? ??

webkit核心的瀏覽器(chrome)中,當css中定義的中文font-size小於12px的時候,瀏覽器仍然使用12px,這時就可以用-webkit-text-size -adjust:none;

哈哈,這樣我們的問題就解決了


#最後說下inline-block的兼容性:參考這篇文章
-->
IE6、IE7不辨識inline-block但可以觸發區塊元素。其它主流瀏覽器皆支援inline-block。這就夠了,ie6,7就不考慮了,原因嘛,你懂的...

相關推薦:

css中display:inline-block與float在讓元素排列在一行時使用差異

css:block,inline和inline-block用法和差異

##css解決display:inline- block;佈局產生的縫隙的方法



#

以上是關於Css3的inline-block遇到的坑的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

純CSS3怎麼實現波浪效果? (程式碼範例) 純CSS3怎麼實現波浪效果? (程式碼範例) Jun 28, 2022 pm 01:39 PM

純CSS3怎麼實現波浪效果?這篇文章就來跟大家介紹一下使用 SVG 和 CSS 動畫來製作波浪效果的方法,希望對大家有幫助!

巧用CSS實現各種奇形怪狀按鈕(附代碼) 巧用CSS實現各種奇形怪狀按鈕(附代碼) Jul 19, 2022 am 11:28 AM

這篇文章帶大家看看怎麼使用 CSS 輕鬆實現高頻出現的各類奇形怪狀按鈕,希望對大家有幫助!

css怎麼隱藏元素但不佔空間 css怎麼隱藏元素但不佔空間 Jun 01, 2022 pm 07:15 PM

兩種方法:1、利用display屬性,只要為元素加上「display:none;」樣式即可。 2.利用position和top屬性設定元素絕對定位來隱藏元素,只需為元素加上「position:absolute;top:-9999px;」樣式。

css3怎麼實現花邊邊框 css3怎麼實現花邊邊框 Sep 16, 2022 pm 07:11 PM

在css中,可以利用border-image屬性來實作花邊邊框。 border-image屬性可以使用圖片來建立邊框,即給邊框加上背景圖片,只需要將背景圖片指定為花邊樣式即可;語法「border-image: url(圖片路徑) 向內偏移值圖像邊界寬度outset 是否重複;」。

css3如何實現滑鼠點擊圖片放大 css3如何實現滑鼠點擊圖片放大 Apr 25, 2022 pm 04:52 PM

實作方法:1、使用「:active」選擇器選取滑鼠點擊圖片的狀態;2、使用transform屬性和scale()函數實現圖片放大效果,語法「img:active {transform: scale(x軸放大倍率,y軸放大倍率);}」。

原來利用純CSS也能實現文字輪播與圖片輪播! 原來利用純CSS也能實現文字輪播與圖片輪播! Jun 10, 2022 pm 01:00 PM

怎麼製作文字輪播與圖片輪播?大家第一想到的是利用js,其實利用純CSS也能實現文字輪播與圖片輪播,下面來看看實作方法,希望對大家有幫助!

css3怎麼設定動畫旋轉速度 css3怎麼設定動畫旋轉速度 Apr 28, 2022 pm 04:32 PM

在css3中,可以利用「animation-timing-function」屬性來設定動畫旋轉速度,該屬性用於指定動畫將如何完成一個週期,設定動畫的速度曲線,語法為「元素{animation-timing-function:速度屬性值;}」。

css3動畫效果有變形嗎 css3動畫效果有變形嗎 Apr 28, 2022 pm 02:20 PM

css3中的動畫效果有變形;可以利用「animation:動畫屬性@keyframes ..{..{transform:變形屬性}}」實現變形動畫效果,animation屬性用於設定動畫樣式,transform屬性用於設定變形樣式。

See all articles