Skip to main content

Intermediate CSS: Box Model

Many web pages use box model to organize the web content. For example, when I inspect MDN homepage, I see there are box shapes on the page. Some boxes are visible, but some boxes are invisible.


No matter those boxes are visible or invisible, the main purpose to use box model is to let the web page have an appropriate layout, which allow users to catch the clear information and easy to read.

What Is The Box Model?

According to MDN, in a document, each element is represented as a rectangular box. In CSS, each of these rectangular boxes is described using the standard box model. 

Each box has four edges: margin, border, padding and content edge.

From MDN

Content:The content of a CSS box is where the text and images appear. The "width" and "height" properties set the width and height of content box. 

Padding: Padding refers to the inner margin of a CSS, and it is transparent. The properties include padding-top, padding-right, padding-bottom, and padding-left. 

Border: The border of a CSS box goes around the padding and content. The properties include border-top, border-right, border-bottom, and border-left. And we can also set the border width, style, and color.

Margin: The margin surrounds a CSS box, and it is outside the border. It is also transparent. The properties includes: margin-top, margin-left, margin-bottom, and margin-right. (Above Definition are From MDN Box Model)

Now I am going to show an example to explain each element of CSS box.

I create a simple HTML page includes two "headers" and one "content". Each content has a border around it. 

In order to let you see how the box change, I will only make the red content box change. 


I begin from the outside CSS box to inside box. Firstly, I set the outside box margin 50px. You can see the space between two black box and red box are getting bigger. 

Secondly, I set the padding, the inside margin, as 50px, too. The inside margin is larger than the previous one.


If you want to move the "content" to the center, you can also try to set the padding-left properties.

Thirdly, I set the border. I only change the border-bottom to "10px dashed blue" style, so you can see the difference between the red and blue border.


Lastly, I set the content width and height in 200px, then the red box become a square.


You can always inspect (right click the web page and select the inspect) the page and change the property value and see the differences. 

Comments

Popular posts from this blog

Intermediate Express.js: How To Add Styles & Partials in EJS File?

So far, we only have simple HTML tags and ejs tags in each ejs file. Every template page has no style at all. And the basic HTML header and footer are also missing. Today, I learned how to add styles and partials in ejs file. Link Style Step One: Touch a Separate CSS file I create a new directory "Style" under the "EJSDemo" directory, then I add a new CSS file "app.css" inside "Style" folder. Step Two: Add app.use(express.static()) in the app.js I add app.use(express.static("style")) in the "app.js". This will tell Express.js to serve the content of "Style" directory. Step Three: Write styles in CSS file I simple give body an orange background color and set text color to be grey. Step Four: Link to CSS file in the EJS file I just add <link> tag to link the "app.css" file on the top of the h1 tag in each ejs template. As the result, when I run the app and...

Intermediate CSS: Three Steps To Create A Photo Gallery

I have seen many image blogs these years. People love to post their photos online to express life and feeling.  Image is powerful because it could bring a visual story to audience. People can see what you see, and may be feel the same way as you feel, too. If we want to build our own photo gallery, what should we do? Luckily, the boot-camp instructor just showed me how to use HTML and CSS to create a simple photo gallery.  I would love to share my study note here. (p.s. all the image links are provided by Udemy course instructor) Step One: Add Image Links on HTMLPage The instructor provides all the image links. All we need to do is add those links inside the <img> tag. Without CSS, the page will looks like this: they are not organized, and sizes are different, too. Step Two: Set Image Property Values We set the width of each photo the same value which is 30%, so there will be three images per line. The percentage value can help...

Three Most Common HTML Form Elements You Should Know

When I visited the Facebook page at the first time, it required me to sign up. Therefore, I completed the sign up form to create my new account. The form is very simple to fill in because it only asks for very common information such as full name, phone number, new password, birthday, and gender. It only took me one or two minutes to finish the form. Not only Social media sites require us to sign up first before we post anything, but many business or eCommerce sites also ask us to create new account before we take any action. For example, when I go to the Origins skin care site, it will pop up a email sign up form window. To encourage new customers to sign up, it gives a 15% off for the first order. It is definitely an attractive call-to-action message. Anyway, if your website requires users to sign up, you need to know how to create a HTML form. Yesterday, I just learned how to build a simple HTML form from Udemy course. And it is not that hard. All you need to kno...