移除行块级元素之间的空格(译文)_html/css_WEB-ITnose
引言
我现在仍然记得作为一个IE6时代的初级开发者拼命的渴望IE拥有display: inline-block;这个属性。当我们想控制间距和填充在inline元素儿不用block and float的时候,inline-block这个属性是及其的有用。
然而,使用inline-block的时候有一个问题,视觉上两个元素之间会出现空白。
有很多办法移除这些恼人的空白
方法 0
唯一一个百分之百解决这个问题的方案是这样:不要在这些元素的源码之间出现空白。
<style type="text/css">ul,li{ margin: 0; padding: 0;}li{ list-style: none; display: inline-block; border: 1px solid black; padding: 2px;}</style><ul><li>Item</li><li>Item</li><li>Item</li></ul>
下面是效果:
当然了,这个维护起来比较麻烦,但他很实用、和逻辑,最重要的是比较可靠。
方法 1
最好的空白解决方案:设置行区块元素的父元素font-size: 0。因此如果你有一个
元素包裹了一堆
<style type="text/css">ul,li{ margin: 0; padding: 0;}li{ list-style: none; display: inline-block; border: 1px solid black; padding: 2px;}.inline-block-list{ font-size: 0;}.inline-block-list li{ font-size: 14px;}</style><ul class="inline-block-list"> <li>Item</li> <li>Item</li> <li>Item</li></ul>
这种情况一般情况下和方法 0是一样的结果,不过在IE8中,如果给行块级元素设置了position:absolute,这个会导致一个严重的问题,页面直接就是全部空白了。
方法 2
这种方法有点取巧的意思,但仍然可以用。在行块元素之间使用HTML注释,这个原理也是在元素源码之间没有空格
<style type="text/css">ul,li{ margin: 0; padding: 0;}li{ list-style: none; display: inline-block; border: 1px solid black; padding: 2px;}.inline-block-list{ font-size: 0;}.inline-block-list li{ font-size: 14px;}.three{ position: absolute; margin-left: 20px;}</style><ul class="inline-block-list"> <li>Item</li><!-- --><li>Item</li><!-- --><li class="three">Item</li></ul>
用一个单词形容这个。。。流氓(gross),两个单词形容这种方法。。。真流氓(really gross)。用三个单词。。。就是——你可以使用它(you get it)。他可以正常的显示。
方法 3
和方法 2类似,这个方法也有点令人遗憾。你可以利用行块元素的灵活性,用负的间距抵消空白
<style type="text/css">ul,li{ margin: 0; padding: 0;}li{ list-style: none; display: inline-block; border: 1px solid black; padding: 2px;}.inline-block-list li{ margin-left: -4px;}</style><ul class="inline-block-list"> <li>Item</li> <li>Item</li> <li>Item</li></ul>
这是一个很差劲的方案,你必须计算这个负间距是多少,有时候还会有不可预料的空白。所以,尽量避免使用这种来解决行块元素之间的空白。
方法 4
另外一个基于HTML的hack解决方案就是——只需要将闭合标签>放到下一个标签的开始:
<style type="text/css">ul,li{ margin: 0; padding: 0;}li{ list-style: none; display: inline-block; border: 1px solid black; padding: 2px;}.inline-block-list{ font-size: 0;}.inline-block-list li{ font-size: 14px;}</style><ul class="inline-block-list"> <li>Item</li ><li>Item</li ><li>Item</li></ul>
跟HTML注释这种方式相比,没有那么难看,但我知道,我可以移除空白,但没有去考虑这些空白为什么会存在。
所有的这些解决方案没有一个是完美的,唯一可以选择的在HTML中不要使用空格和缩进也是一个不太好的方案。这不是告诉你“注意使用什么方案”,因为inline-block仍然非常的有用,但当开发者使用它的时候知道如何处理空白非常的重要。
方法 my
我的方法是使用浮动,这个在IE7中也是ok的,前面的这些方法在IE系列中某些低版本可能会失效(inline-block不起作用)
<style type="text/css">ul,li{ margin: 0; padding: 0;}ul:after{ content: '.'; height: 0; visibility: hidden; display: block; clear: both;}li{ list-style: none; display: inline-block; border: 1px solid black; padding: 2px; float: left;}</style><ul class="inline-block-list"> <li>Item</li> <li>Item</li> <li>Item</li></ul>
LAST
author: 燕睿涛
email: ritoyan@163.com

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Le cache de mise à jour de la page Web du compte officiel, cette chose est simple et simple, et elle est suffisamment compliquée pour en boire un pot. Vous avez travaillé dur pour mettre à jour l'article officiel du compte, mais l'utilisateur a toujours ouvert l'ancienne version. Dans cet article, jetons un coup d'œil aux rebondissements derrière cela et comment résoudre ce problème gracieusement. Après l'avoir lu, vous pouvez facilement faire face à divers problèmes de mise en cache, permettant à vos utilisateurs de toujours ressentir le contenu le plus frais. Parlons d'abord des bases. Pour le dire franchement, afin d'améliorer la vitesse d'accès, le navigateur ou le serveur stocke des ressources statiques (telles que des images, CSS, JS) ou du contenu de la page. La prochaine fois que vous y accédez, vous pouvez le récupérer directement à partir du cache sans avoir à le télécharger à nouveau, et il est naturellement rapide. Mais cette chose est aussi une épée à double tranchant. La nouvelle version est en ligne,

L'article discute de l'utilisation des attributs de validation de formulaire HTML5 comme les limites requises, motifs, min, max et longueurs pour valider la saisie de l'utilisateur directement dans le navigateur.

L'article examine les meilleures pratiques pour assurer la compatibilité des navigateurs de HTML5, en se concentrant sur la détection des fonctionnalités, l'amélioration progressive et les méthodes de test.

Cet article démontre un ajout de bordure PNG efficace aux pages Web à l'aide de CSS. Il soutient que CSS offre des performances supérieures par rapport à JavaScript ou à des bibliothèques, détaillant comment ajuster la largeur, le style et la couleur des bordures pour un effet subtil ou proéminent

L'article traite du HTML & lt; Datalist & GT; élément, qui améliore les formulaires en fournissant des suggestions de saisie semi-automatique, en améliorant l'expérience utilisateur et en réduisant les erreurs. COMMANDE COMPRES: 159

L'article traite du HTML & lt; Progress & GT; élément, son but, son style et ses différences par rapport au & lt; mètre & gt; élément. L'objectif principal est de l'utiliser & lt; Progress & gt; pour l'achèvement des tâches et & lt; mètre & gt; pour stati

Cet article explique le html5 & lt; time & gt; élément de représentation sémantique de date / heure. Il souligne l'importance de l'attribut DateTime pour la lisibilité à la machine (format ISO 8601) à côté du texte lisible par l'homme, stimulant AccessIbilit

L'article traite du HTML & lt; mètre & gt; élément, utilisé pour afficher des valeurs scalaires ou fractionnaires dans une plage, et ses applications courantes dans le développement Web. Il différencie & lt; mètre & gt; De & lt; Progress & gt; et ex
