CSS Position

In CSS, the position property is used to specify how an element is positioned in a document. There are several possible values for the position property:

position: static

position: static is the default positioning for all HTML elements. When an element has a position value of static, it is placed in the normal document flow, meaning it follows the standard layout rules without any special positioning. The top, right, bottom, and left properties do not apply to elements with position: static.

Syntax


.static-element {
    position: static;
}

Note: position: static is the default value, you don’t actually need to specify it unless you’re overriding another position value.

position: relative

position: relative is a CSS property that allows an element to be positioned relative to its normal position in the document flow. When an element is given a position value of relative, it remains in the normal flow of the document, but you can adjust its position using the top, right, bottom, and left properties. These properties will offset the element from where it would normally be placed without changing the layout of surrounding elements.

Syntax:


.relative-element {
    position: relative;
    top: 20px;
    left: 30px;
}

Example:


<!DOCTYPE html>
<html lang="en">
<head>
    <style>
        .relative-element {
            position: relative;
            top: 20px;
            left: 20px;
            background-color: lightcoral;
            padding: 10px;
            margin: 10px;
        }
        .normal-element {
	  background-color: green;
	}
    </style>
</head>
<body>
    <div class="relative-element">This is a relatively positioned element.</div>
    <div class="normal-element">This is a normal static element.</div>
</body>
</html>
This is a relatively positioned element.
This is a normal static element.

In this example:

  • The div with the class relative-element has a position value of relative.
  • The top: 20px and left: 20px properties move the element 20 pixels down and 20 pixels to the right from its normal position.
  • The element remains in the document flow, so it occupies its original space. The next element in the document flow will not move into the space of the relatively positioned element.

position: absolute

position: absolute is a CSS property that allows an element to be positioned relative to its closest positioned ancestor. An element with position: absolute is removed from the normal document flow, meaning it does not affect the layout of surrounding elements and is not affected by them. Instead, its position is determined by the top, right, bottom, and left properties.

Syntax:


.absolute-element {
    position: absolute;
    top: 50px;
    left: 100px;
}

Example:


<html lang="en">
<head>
    <style>
        .relative-container {
            position: relative;
            width: 300px;
            height: 200px;
            background-color: lightgray;
        }

        .absolute-element {
            position: absolute;
            top: 20px;
            left: 30px;
            background-color: lightgreen;
            padding: 10px;
        }
    </style>
</head>
<body>
    <div class="relative-container">
        This is a relatively positioned container.
        <div class="absolute-element">This is an absolutely positioned element.</div>
    </div>
</body>
</html>
This is a relatively positioned container.
This is an absolutely positioned element.

position: fixed

position: fixed is a CSS property that positions an element relative to the browser window, rather than its containing element. A fixed-position element stays in the same place on the screen, even when the page is scrolled. This makes it useful for creating elements like sticky headers, footers, or floating buttons.

Key Points:

1. Fixed Positioning: The element is positioned relative to the viewport and does not move when the page is scrolled.

2. Offset Properties: The top, right, bottom, and left properties determine the position of the element relative to the viewport.

3. Removed from Normal Flow: The element is taken out of the normal document flow, so it does not affect the layout of other elements and vice versa.

Syntax:


.fixed-element {
    position: fixed;
    top: 0;
    right: 0;
}

Example:


<html lang="en">
<head>
    <style>
        .fixed-element {
            position: fixed;
            top: 10px;
            right: 10px;
            background-color: lightpink;
            padding: 10px;
            border: 1px solid #000;
        }

        .content {
            height: 1500px; /* Adding height to demonstrate scrolling */
            background-color: lightgray;
            padding: 10px;
        }
    </style>
</head>
<body>
    <div class="fixed-element">This is a fixed element.</div>
    <div class="content">
        Scroll down to see the fixed element stay in place.
    </div>
</body>
</html>

position: sticky

position: sticky is a CSS property that allows an element to switch between relative and fixed positioning, depending on the user’s scroll position. A sticky element toggles between relative and fixed positioning based on the scroll position in the document. When the element reaches a specified point in the scroll, it sticks to that position (like fixed) until its containing block is out of view.

Key Points:

1. Relative Positioning: The element is positioned according to the normal flow of the document until a specified scroll position is reached.

2. Fixed Positioning: Once the specified scroll position is reached, the element becomes fixed and remains at that position relative to the viewport until its container is scrolled out of view.

3. Offset Properties: The top, right, bottom, and left properties are used to define the point at which the element becomes sticky.

Syntax:


.sticky-element {
    position: sticky;
    top: 0;
}

Example:


<!DOCTYPE html>
<html lang="en">
<head>
    <style>
        .sticky-container {
            height: 2000px; /* Adding height to demonstrate scrolling */
            background-color: lightgray;
            padding: 10px;
        }

        .sticky-element {
            position: sticky;
            top: 10px; /* Becomes fixed 10px from the top of the viewport */
            background-color: lightyellow;
            padding: 10px;
            border: 1px solid #000;
        }
    </style>
</head>
<body>

    <div class="sticky-container">
        <div class="sticky-element">This is a sticky element.</div>
        <p>Scroll down to see the sticky effect.</p>
        <p>Content...</p>
        <p>Content...</p>
        <p>Content...</p>
        <p>Content...</p>
        <p>Content...</p>
        <p>Content...</p>
    </div>

</body>
</html>