What you have stumbled across is the foundation of the CSS box-model.
You can play with it using the box-sizing
property which has two possible values:
- content-box (default)
- border-box
content-box Default. The width and height properties (and min/max properties) includes only the content. Border, padding, or margin are
not included
border-box The width and height properties (and min/max properties) includes content, padding and border, but not the margin
(source: W3Schools.com)
By default, the border will add on to your container width/height.
See what happens when you use border-box
:
.test{
width:300px;
height:auto;
background-color:#A8F9C0;
float:left;
border:2px solid black;
box-sizing: border-box;
}
<div class="test">
</div>
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…