CSS Positions

·

3 min read

CSS Positions

Hi Friends, I have written a blog on CSS Positioning, hope it will easy to read and understand.

CSS Positions Property with Example

Position Property has 5 values-

  • Static
  • Relative
  • Absolute
  • Fixed
  • Sticky

Sticky Position

  • It is default position of every element.
  • Explanation- lets take a box and we can see there will be no change in box position.

    by applying static position nothing is change.

//HTML Code-
<body>
  <div class="container">
  <div class="child"></div>
  </div>
</body>

//CSS Code-
*{
  margin:0;
  padding:0;
  box-sizing: border-box;   
}
.container{
  height:100px;
  width:100px;
  border:1px solid black;
  background-color:lightgreen;
  position:static;
}

static.JPG

Relative & Absolute

Both works in same way except that

  • Relative -> works on Parent Class
  • Absolute -> words on Children class

Explanation- lets take a box means we are working only on container, child is not in role till now.

After applying position relative we can see box moved 100px from left.

//HTML Code-
<body>
  <div class="container">
  <div class="child"></div>
  </div>
</body>

//CSS Code-
*{
  margin:0;
  padding:0;
  box-sizing: border-box;   
}
.container{
  height:100px;
  width:100px;
  border:1px solid black;
  background-color:lightgreen;
  position:relative;
  left:100px;
}

Relative.JPG

Relative vs Absolute

Now lets take a children to explain it. child box moved 100px from its parent means outer box as seen in below image.

//HTML Code-
<body>
  <div class="container">
  <div class="child"></div>
  </div>
</body>

//CSS Code-
*{
  margin:0;
  padding:0;
  box-sizing: border-box;   
}
.container{
  height:300px;
  width:300px;
  border:1px solid black;
  background-color:lightgreen;
  position:relative;
}
.child{
  width:100px;
  height:100px;
  background-color:pink;
  border:1px solid black;
  position:absolute;
  left:100px
}

Relative vs absolute.JPG

  • Suppose we are giving relative position to body not the parent box then output will be shown like below. here we are assuming that parent box is in middle of the page
body {
  position: relative;
}
.container {
  height: 300px;
  width: 300px;
  margin:auto;
  border: 1px solid black;
  background-color: lightgreen;
}
.child {
  width: 100px;
  height: 100px;
  background-color: pink;
  border: 1px solid black;
  position: absolute;
  left: 100px;
}

bodyrelative.JPG

Fixed Position After applying fixed position to the box it has fixed at its given position. Even we scroll, it will no move from its fixed position i.e. 100px from top and 200px from left.

//HTML Code-
<body>
  <div class="container">
    <p>Lorem ipsum dolor, sit amet consectetur adipisicing elit. 
     Tempore, soluta?</p>
  <div class="child-box"></div>
   <p>Lorem ipsum dolor, sit amet consectetur adipisicing elit. 
    Tempore, soluta?</p>
</div>
</body>

//CSS Code-
.container {
  height: 1000px;
}
.child-box {
  width: 100px;
  height: 100px;
  background-color: pink;
  border: 1px solid black;
  position: fixed;
  top:100px;
  left: 200px;
}

Fixed.JPG

Sticky Position

//CSS Code-
.child-box {
  width: 100px;
  height: 100px;
  background-color: pink;
  border: 1px solid black;
  position: sticky;
  top:10px;
  left: 200px;
}

We can understand by below example-

  • After applying sticky position to the box- if we check without scrolling it will remain at its original position means 200px from left.

stickoriginal.JPG

  • But when we check with scrolling, box moves up but when it reached at given position means 10px from top then it sticks there.

stickmove.JPG