- 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: Position
The position property in CSS is used to specify how an element is positioned in a document. It can be used to position elements in various ways, such as relative to their normal position, fixed relative to the viewport, or absolute relative to their nearest positioned ancestor.
Values of position
static:
- The default value. Elements are positioned according to the normal document flow. top, right, bottom, left, and z-index properties have no effect.
relative:
- The element is positioned relative to its normal position. It allows the use of top, right, bottom, and left to move the element from its normal position.
absolute:
- The element is positioned relative to its nearest positioned ancestor (an ancestor with position set to relative, absolute, fixed, or sticky). If there is no such ancestor, it is positioned relative to the initial containing block (the document).
fixed:
- The element is positioned relative to the viewport, which means it always stays in the same place even when the page is scrolled. It is also removed from the normal document flow.
sticky:
- The element is positioned based on the user's scroll position. It toggles between relative and fixed, depending on the scroll position. It's treated as relative until it crosses a specified point (defined by top, right, bottom, or left), after which it is treated as fixed.
Examples and Use Cases
static
<div class="static-element">This is a static element.</div>
<style>
.static-element {
position: static;
}
</style>
relative
<div class="relative-element">This is a relatively positioned element.</div>
<style>
.relative-element {
position: relative;
top: 10px; /* Moves the element down by 10px from its normal position */
left: 20px; /* Moves the element right by 20px from its normal position */
}
</style>
absolute
<div class="parent">
<div class="absolute-element">This is an absolutely positioned element.</div>
</div>
<style>
.parent {
position: relative; /* This makes the parent a positioned ancestor */
}
.absolute-element {
position: absolute;
top: 10px;
right: 20px;
}
</style>
fixed
<div class="fixed-element">This is a fixed element.</div>
<style>
.fixed-element {
position: fixed;
bottom: 0; /* Stays at the bottom of the viewport */
right: 0; /* Stays at the right of the viewport */
}
</style>
sticky
<div class="sticky-container">
<div class="sticky-element">This is a sticky element.</div>
<p>Scroll down to see the sticky behavior.</p>
<!-- Add more content here to enable scrolling -->
</div>
<style>
.sticky-container {
height: 200vh; /* Make container tall enough to enable scrolling */
}
.sticky-element {
position: sticky;
top: 0; /* Sticks to the top of the container when you scroll past it */
}
</style>
Additional Notes
- z-index: The z-index property can be used in conjunction with position to control the stacking order of positioned elements. It only works on elements that have a position value other than static.
- Combining positions: You can use position in combination with other properties to create complex layouts. For example, using position: absolute; inside a position: relative; container is a common pattern for overlay elements or custom tooltips.
Understanding the position property and its values is crucial for creating complex layouts and designs in CSS. Each value provides a different way to control the placement and behavior of elements on the page.