box-sizing

suggest change

The default box model (content-box) can be counter-intuitive, since the width / height for an element will not represent its actual width or height on screen as soon as you start adding padding and border styles to the element.

The following example demonstrates this potential issue with content-box:

textarea {
    width: 100%;
    padding: 3px;
    box-sizing: content-box; /* default value */
}

Since the padding will be added to the width of the textarea, the resulting element is a textarea that is wider than 100%.

Fortunately, CSS allows us to change the box model with the box-sizing property for an element. There are three different values for the property available:

To solve the textarea problem above, you could just change the box-sizing property to padding-box or border-box. border-box is most commonly used.

textarea {
    width: 100%;
    padding: 3px;
    box-sizing: border-box;
}

To apply a specific box model to every element on the page, use the following snippet:

html {
    box-sizing: border-box;
}

*, *:before, *:after {
    box-sizing: inherit;
}

In this coding box-sizing:border-box; is not directly applied to \*, so you can easily overwrite this property on individual elements.

Feedback about page:

Feedback:
Optional: your email if you want me to get back to you:



Table Of Contents