Lors de l'utilisation d' inline-blockéléments, il y aura toujours un whitespace problème entre ces éléments (cet espace mesure environ 4 px de large).
Donc, vos deux divs, qui ont tous deux une largeur de 50%, plus cela whitespace(~ 4px) a plus de 100% de largeur, et donc ça casse. Exemple de votre problème:
body{
margin: 0; /* removing the default body margin */
}
div{
display: inline-block;
width: 50%;
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<div class="left">foo</div>
<div class="right">bar</div>
Il existe plusieurs façons de résoudre ce problème:
1. Aucun espace entre ces éléments
body{
margin: 0; /* removing the default body margin */
}
div{
display: inline-block;
width: 50%;
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<div class="left">foo</div><div class="right">bar</div>
2. Utilisation des commentaires HTML
body{
margin: 0; /* removing the default body margin */
}
div{
display: inline-block;
width: 50%;
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<div class="left">foo</div><!--
--><div class="right">bar</div>
3. Définissez les parents font-sizesur 0, puis ajoutez de la valeur aux inline-blockéléments
body{
margin: 0; /* removing the default body margin */
}
.parent{
font-size: 0; /* parent value */
}
.parent > div{
display: inline-block;
width: 50%;
font-size: 16px; /* some value */
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<div class="parent">
<div class="left">foo</div>
<div class="right">bar</div>
</div>
4. Utiliser une marge négative entre eux ( pas préférable )
body{
margin: 0; /* removing the default body margin */
}
div{
display: inline-block;
width: 50%;
margin-right: -4px; /* negative margin */
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<div class="left">foo</div>
<div class="right">bar</div>
5. Abaissement de l'angle de fermeture
body{
margin: 0; /* removing the default body margin */
}
div{
display: inline-block;
width: 50%;
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<div class="left">foo</div
><div class="right">bar</div>
<hr>
<div class="left">foo</div><div class="right">
bar</div>
6. Ignorer certaines balises de fermeture HTML (merci @thirtydot pour la référence )
body{
margin: 0; /* removing the default body margin */
}
ul{
margin: 0; /* removing the default ul margin */
padding: 0; /* removing the default ul padding */
}
li{
display: inline-block;
width: 50%;
}
.left{
background-color: aqua;
}
.right{
background-color: gold;
}
<ul>
<li class="left">foo
<li class="right">bar
</ul>
Références:
- Combattre l'espace entre les éléments de bloc en ligne sur les astuces CSS
- Supprimer les espaces entre les éléments de bloc en ligne par David Walsh
- Comment supprimer l'espace entre les éléments de bloc en ligne?
Comme @ MarcosPérezGude dit , la meilleure façon est d'utiliser rem, et ajouter une certaine valeur par défaut font-sizesur l' htmlétiquette (comme dans HTML5Boilerplate ). Exemple:
html{
font-size: 1em;
}
.ib-parent{ /* ib -> inline-block */
font-size: 0;
}
.ib-child{
display: inline-block;
font-size: 1rem;
}
Mise à jour : comme nous sommes près de 2018., utilisez flexbox ou encore mieux - disposition en grille CSS .