DEV Community

Nesha Zoric
Nesha Zoric

Posted on

How to Treat Your CSS Elements: The Box-sizing Property

In the previous article that covers CSS subjects, I talked about the box model. An important property that’s connected to the box model is the box-sizing property.

The box-sizing property defines how the height and width of the element are calculated and if it should include the border, padding and margin or not.

Values

There are two possible values for the box-sizing property:

  • Content-box - the default value.
  • Border-box.

Let's see how the width is calculated in both cases.

For a reminder, the box model looks like this:

box_7-1

Content-box

The default value of the box-sizing property is content-box. I will explain how the width is calculated in this case.

Even though I set the width of the element to 200px, the actual width will be much different. The formula is:

Width = left margin + left border + left padding + content + right padding + right border + right margin

So, in the case of the previous example the width would be:

Width = 20px + 3px + 10px + 200px + 10px + 3px + 20px

The result of this calculation is 266px. This is probably not the result you expected, am I right? That’s why you need to really be careful about this.

Now, you’re probably wondering if there is an easier way to deal with width, than having to use the calculator every time? There is! By using border-box.

Border-box

Let’s take the previous example. We specified the width of the element to be 200px, and the padding is 10px on each side. If you were to use content-box, then it’s becoming 220px.

But, when using border-box, the width will be 200px, which means the width of the content will be 180px and the padding is 20px. The content shrinks in size, to accommodate the addition of padding.

Example

Let’s see a visual example of both situations to better explain the properties.

HTML

<div class=”content-box”>Content-box</div>
<div class=”border-box”>Border-box</div>

CSS

div {
  height: 200px;
  width: 200px;
  background-color: hotpink;
  color: #fff;
  padding: 10px;
  border: solid 3px black;
  margin: 20px;
}

.content-box {
  box-sizing: content-box
}

.border-box {
  box-sizing: border-box;
}

content

As you see, in the first example, the width of the content-box adds up to 266px, while the border-box adds up to 200px.

Conclusion

There is a significant connection between the box-sizing property and the box model, and it is an important one. It is of great value to understand both the content-box and border-box value of the box-sizing property. While the content-box is the default value, it is much easier to use the border-box property to avoid calculations which are often confusing.

Happy coding! :)

This post is originally published on Kolosek Blog.

@Mattia Astorino Here's the article, as promised!

Top comments (6)

Collapse
 
chiangs profile image
Stephen Chiang

Great article, border-box is a great way to make things a little simpler.

For those wondering, there are a few ways to set it as the default(ish) behavior:

Method 1

* {
  box-sizing: border-box;
}
Enter fullscreen mode Exit fullscreen mode

Method 2

*, *:before, *:after {
    box-sizing: border-box;
}
Enter fullscreen mode Exit fullscreen mode

Method 3

html {
    box-sizing: border-box;
}

*, *:before, *:after {
    box-sizing: inherit;
}
Enter fullscreen mode Exit fullscreen mode

I prefer method 2, as it keeps it more simple and straight-forward for me, however, method 3 gives more flexibility as then the developer can choose when to use content-box at will. The flip-side to that is that means border-box can't be inherited normally.

Collapse
 
abdiko25 profile image
Abdi Ali

It's amazing how wonderful you explained the difference and impacts on implications

Collapse
 
livingarete profile image
Muzu2020

How does border-box affect margin, does it exist at all in border-box?

Collapse
 
ismail_mb profile image
Isma'il Hassan

Thanks, I find this helpful because it's confusing me, and I didn't give it a specific time to learn and understand it very well, until now

Collapse
 
tluanga34 profile image
Lalnuntluanga

border-box should have been the default property. content-box just makes it frustrating to have the size being changed after adding padding even though we want it to be fixed width and height.

Some comments may only be visible to logged-in visitors. Sign in to view all comments.