Beispielcode wie folgt aus:Warum verursacht dieser Inline-Block zusätzliche Höhe des übergeordneten Elements?
.c1 {
width: 480px;
height: 480px;
background-color: blue;
}
.c2 {
width: 100%;
background-color: red;
}
.c3 {
display: inline-block;
margin-top: 0;
}
<div class="c1">
<div class="c2">
<div class="c3">
</div>
</div>
</div>
Warum die div.c2 angezeigt wird? Es existiert nicht, wenn c3 display
außer Inline-Block hat.
Siehe auch diese codepan: https://codepen.io/uuhan/pen/ZXWodw
UPDATE:
I add line-height: 0 bis C2, dann dünner div.c2 geworden. Aber wie kann ich diese Höhe (6px, mit Ursprung 22px) von c2 herausfinden?
Siehe auch diese codepan: https://codepen.io/uuhan/pen/EwKRLK
Verstanden. Bedeutet dies, dass der Inline-Block immer eine Zeile enthält? – uuhan
Nun, Sie können auch "Höhe: 0" anstelle der Schriftgröße (https://codepen.io/anon/pen/RLaJMx), aber wenn Sie keine tun, wird es so hoch wie sein eine Textzeile – Johannes
Ich füge line-height hinzu: 0 bis c2 Klasse, die Höhe wird dünner. Ich frage mich, wie diese Höhe (6px, und die Ursprung Höhe, 22px) berechnet wird? – uuhan