Skip to content Skip to sidebar Skip to footer

Loop Div Background-color Through All Rainbow Colors Gradually | CSS

How to change the background-color of a div over time through all color of a rainbow and then set it back again to its original color and loop that process infinitely ? The code be

Solution 1:

You can create css animation to change background color. To make animation loop you can add infinite and to get smooth transition of colors you can use linear

div {
  background-color: #FF0000;
  animation: bgColor 5s infinite linear;
  width: 200px;
  height: 100px;
}
@keyframes bgColor {
  12.5% {
    background-color: #FF0000;
  }
  25% {
    background-color: #FFA500;
  }
  37.5% {
    background-color: #FFFF00;
  }
  50% {
    background-color: #7FFF00;
  }
  62.5% {
    background-color: #00FFFF;
  }
  75% {
    background-color: #0000FF;
  }
  87.5% {
    background-color: #9932CC;
  }
  100% {
    background-color: #FF1493;
  }
}
<div></div>

Solution 2:

You need to use keyframes to animate css

#rainbow {
background-color: blue;  
  float:left;
  width: 70px;
  height:70px;
  border: 1px solid white;
  -webkit-animation-name: example; /* Chrome, Safari, Opera */
  -webkit-animation-duration: 4s; /* Chrome, Safari, Opera */
  animation-name: example;
  animation-duration: 4s;
  animation-iteration-count: infinite;
}

@keyframes example {
    0%   {background-color: red; }
    25%  {background-color: yellow; }
    50%  {background-color: blue; }
    75%  {background-color: green; }
    100% {background-color: red; }
}

/* Chrome, Safari, Opera */
@-webkit-keyframes example {
    0%   {background-color: red; }
    25%  {background-color: yellow; }
    50%  {background-color: blue; }
    75%  {background-color: green; }
    100% {background-color: red; }
}
<div id="rainbow"></div>

Solution 3:

you can achieve this with keyframes

.rainbow {
  float:left;
  width: 70px;
  height:70px;
  border: 1px solid white;
 
}

.rainbow:last-child { 
  float:left;
  border: 1px solid white;
  clear:both;
}
@keyframes color {
  0% {
    background-color: red; 
  }
  10% {
    background-color: orange; 
  }
  20% {
    background-color: yellow;  
  }
  30% {
    background-color: Chartreuse;  
  }
  40% {
    background-color: cyan; 
  }
  50% {
    background-color: blue; 
  }
  60% {
    background-color: DarkOrchid;  
  }
  70% {
    background-color: DeepPink;
  }
  80% {
    background-color: red; 
  }
  90% {
    background-color: red; 
  }
  100% {
    background-color: red;
  }
}

.rainbow {
   animation: color 8s infinite;
}
<div class="rainbow">Original color</div>
<div class="rainbow">After some time</div>
<div class="rainbow">After some time</div>
<div class="rainbow">After some time</div>
<div class="rainbow">After some time</div>
<div class="rainbow">After some time</div><div class="rainbow">After some time</div><div class="rainbow">After some time</div><div class="rainbow">Come back to red and loop</div>
<br style="clear:both">
All of the above in just one div

Solution 4:

I made this in pure Javascript. (Also on github)

let r = 255
let g = 0
let b = 0

function rgb(r, g, b){
    return "rgb("+r+","+g+","+b+")"
}

function myTimer () {
    if (r < 255 && g == 0 && b == 0) {
        r++
    } else if (r == 255 && g < 255 && b == 0) {
        g++
    } else if (r > 0 && g == 255 && b == 0) {
        r--
    } else if (r == 0 && g == 255 && b < 255) {
        b++
    } else if (r == 0 && g > 0 && b == 255) {
        g--
    } else if (r < 255 && g == 0 && b == 255) {
        r++
    } else if (r == 255 && g== 0 && b > 0) {
        b--
    }
    document.body.style.backgroundColor = rgb(r, g, b)
}

setInterval(myTimer, 10)

Post a Comment for "Loop Div Background-color Through All Rainbow Colors Gradually | CSS"