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

來源:互聯網
上載者:User
本篇文章主要介紹了css解決display:inline-block;產生的縫隙(間隙)的方法,具有一定的參考價值,有需要的可以瞭解一下。

今天在做H5的水平滑動卡片時用到了display:inline-block;卻發現處在同一水平線上的元素之間居然產生了縫隙,這很顯然不是我想要的效果,所以我就換成了左浮動,這樣縫隙的問題是解決了,但是需要設定父元素的寬度才能實現水平左右滾動,這樣又增加了代碼量,因為卡片的個數不固定,需要即時設定其父元素的寬度,就要用到js,所以代碼量增加了,也不是最好的選擇。看來最好的解決辦法就是用到display:inline-block;了,於是縫隙的問題就出現了。代碼如下:


<!DOCTYPE html><html><head><meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"><title>document</title><style>*{margin:0;padding:0;}.box{overflow-x:auto;background:#fff;white-space:nowrap;}.box span{display:inline-block;width:100px;height:30px;line-height:30px;text-align:center;background:#f00;color:#fff;}</style></head><body><p class="box">    <span>111</span>    <span>111</span>    <span>111</span>    <span>111</span></p></body></html>

效果如下:

這個縫隙很明顯存在,據說這種表現是符合規範的應該有的表現,是換行造成的空白符導致的。但這效果很顯然不是我們想要的,我們想要的縫隙是我們根據自己的實際需求而設定的邊距。那麼該如何消除產生的這個縫隙呢?辦法有三:

方法一:元素之間不換行,代碼如下:


<p class="box">  <span>111</span><span>111</span><span>111</span><span>111</span></p>

效果如下:

方法二:給其父元素設定font-size:0;給其自身設定實際需要的字型大小大小。不好的地方就是有些瀏覽器有設定最小字型,像chrome和opera,但是現在的chrome好像沒有這個設定了,代碼如下:

css:


.box{overflow-x:auto;background:#fff;white-space:nowrap;font-size:0;}.box span{display:inline-block;width:100px;height:30px;line-height:30px;text-align:center;background:#f00;color:#fff;font-size:14px;}

html:


<p class="box">    <span>111</span>    <span>111</span>    <span>111</span>    <span>111</span></p>

效果如下:

方法三:負margin方法,需要注意的是這個間隙跟字型大小大小有關係的,所以間隙不是個確定值。

以上三種方法,前兩種是比較好的解決辦法,第三種方法不推薦使用。網上還有其他的解決辦法,但我認為還是前兩種比較好。

PS:

結合廣大前端大神的評論建議來看,也可以給其父元素設定display:flex來消除縫隙,且代碼量少了,但是用在我的水平滑動卡片的效果中導致所有的元素都處在了可視視窗中,就不能實現水平左右滑動了。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.