2016-12-09 2 views
1

Was bewirkt, dass die vertikale Bildlaufleiste hier angezeigt wird? http://codepen.io/anon/pen/QGByOQ?editors=1100Die vertikale Bildlaufleiste wird aus unbekanntem Grund angezeigt.

Wie schlage ich vor, .container ist 100% Höhe von body, Körper erbt html, html ist 100% des viewport, daher sollte jeder .chart perfekt passen, wie es der Höhe ist, ist die Hälfte der .container ist. Trotzdem erscheint eine y-Bildlaufleiste. Was ist das Verhalten dahinter?

html:

<!DOCTYPE html> 
<html lang="en"> 
<head> 
    <meta charset="UTF-8"> 
    <title></title> 
</head> 
<body> 
    <div class="container"> 
     <div class="chart1"></div> 
     <div class="chart1"></div> 
     <div class="chart1"></div> 
     <div class="chart1"></div> 
    </div> 
</body> 
</html> 

css:

.container { 
    width: 100%; 
    height: 100%; 
    border: 5px dashed black; 
    box-sizing: border-box; 
    font-size: 0; 
    overflow: auto; 
} 

html, body { 
    height: 100%; 
} 

body { 
    margin: 0; 
} 

.chart1 { 
    display: inline-block; 
    width: 50%; 
    height: 50%; 
    border: 1px solid red; 
    box-sizing: border-box; 
} 
+0

Ihr Codepen zeigen keine vertikale Bildlaufleiste ... Sie haben das Problem bereits gelöst? – kukkuz

Antwort

2

Dies ist aufgrund der roten Rand des Behälters. Verwenden Sie CSS calc() Funktion, wie:

.chart1 { 
    height: calc(100% - 1px); /* 1px for the extra border */ 
} 

Werfen Sie einen Blick auf das Snippet unten:

.container { 
 
    width: 100%; 
 
    height: 100%; 
 
    border: 5px dashed black; 
 
    box-sizing: border-box; 
 
    font-size: 0; 
 
    overflow: auto; 
 
} 
 

 
html, body { 
 
    height: 100%; 
 
} 
 

 
body { 
 
    margin: 0; 
 
} 
 

 
.chart1 { 
 
    display: inline-block; 
 
    width: 50%; 
 
    height: calc(50% - 1px); 
 
    border: 1px solid red; 
 
    box-sizing: border-box; 
 
}
<div class="container"> 
 
    <div class="chart1"></div> 
 
    <div class="chart1"></div> 
 
    <div class="chart1"></div> 
 
    <div class="chart1"></div> 
 
</div>

hoffe, das hilft!

+0

Ich denke, es sollte -2 Pixel für jeden Divs sein. oben und unten begrenzen – Kebeng

Verwandte Themen