- CSS Tutorial
- CSS Introduction
- CSS Syntax
- CSS Comments
- CSS Selectors
- CSS Fonts
- CSS Colors
- CSS Backgrounds
- CSS Box Model
- CSS Borders
- CSS Margins
- CSS Padding
- CSS Text
- CSS Images
- CSS Links
- CSS Lists
- CSS Tables
- CSS Outline
- CSS Icons
- CSS Display
- CSS max-witdh
- CSS Position
- CSS z-index
- CSS Overflow
- CSS Float
- CSS Align
- CSS Opacity
- CSS Navigation Bar
- CSS Dropdowns
- CSS Forms
- CSS Units
- CSS !important
- CSS Specificity
- CSS Combinators
- CSS inline-block
- CSS Hover
- CSS Cursors
- CSS Selectors
- CSS Type Selector
- CSS Class Selector
- CSS ID Selector
- CSS Attribute Selector
- CSS Pseudo-class Selector
- CSS Pseudo-element Selector
- CSS Universal Selector
- CSS Advanced
- CSS Text Formatting
- CSS Gradients
- CSS Shadow
- CSS Rounded Corners
- CSS Text Effects
- CSS 2D Transform
- CSS 3D Transform
- CSS Border Images
- CSS Inherit
- CSS Transitions
- CSS Animations
- CSS Box Sizing
- CSS Tooltip
- CSS Masking
- CSS Pagination
- CSS Styling Images
- CSS object-fit
- CSS object-position
- CSS Buttons
- CSS Multiple Columns
- CSS Variables
- CSS Flexbox
- CSS Grid
- CSS Media Queries
CSS: Box-Model
The CSS box model is a fundamental concept that describes how elements are structured and rendered on a web page. It consists of several components that define the size, spacing, padding, border, and margins of an element. Understanding the box model is crucial for designing layouts and positioning elements effectively. Here are the main components of the CSS box model:
- Content: The actual content of the HTML element, such as text, images, or other media. The content area is determined by the element's width and height properties.
- Padding (padding): The space between the content area and the element's border. Padding helps create space inside the element and separates the content from the border.
.box {
padding: 20px; /* Applies 20 pixels of padding on all sides */
}
.box-specific {
padding: 10px 20px; /* Applies 10 pixels of padding on top and bottom, 20 pixels on left and right */
}
- Border (border): The border surrounds the padding and content area, creating a visible boundary for the element. You can specify the border's width, style, and color.
.box {
border: 1px solid #000; /* 1-pixel solid black border */
}
.box-rounded {
border: 2px dashed red; /* 2-pixel dashed red border */
border-radius: 10px; /* Adds rounded corners with a 10-pixel radius */
}
- Margin (margin): The space between the element's border and adjacent elements. Margins create spacing and separation between elements in a layout.
.box {
margin: 10px; /* Applies 10 pixels of margin on all sides */
}
.box-specific {
margin: 20px 0; /* Applies 20 pixels of margin on top and bottom, 0 margin on left and right */
}
- Width and Height (width and height): Specify the dimensions of the element's content area. You can use pixels, percentages, ems, or other units to define the width and height.
.box {
width: 200px;
height: 100px;
}
.box-full {
width: 100%;
height: 200px;
}
- Box Sizing (box-sizing): Controls how the total width and height of an element are calculated, taking into account padding and borders. The default behavior is content-box, but you can use border-box to include padding and borders in the width and height calculations.
.box {
width: 200px;
height: 100px;
padding: 20px;
border: 1px solid #000;
box-sizing: border-box; /* Includes padding and border in the width and height calculations */
}
Understanding and using the CSS box model effectively allows you to create well-structured layouts, control spacing, and sizing, and ensure elements are positioned correctly within a webpage.