Loader com HTML e CSS puros!
Achei super bacana a iniciativa do projeto! Totalmente apoiado!
Como meu primeiro post, vou fornecer o código de um loader real que eu fiz e é utilizado em uma das aplicações aqui da empresa onde trabalho!
HTML
<div class="page-loader">
<div class="anim">
<div></div>
<div></div>
<div></div>
<div></div>
</div>
</div>
CSS
.page-loader {
position: fixed;
display: flex;
align-items: center;
justify-content: center;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
background: rgb(255, 255, 255);
z-index: 100;
}
.anim {
display: flex;
justify-content: center;
align-items: center;
}
.anim div {
width: 12px;
height: 12px;
border-radius: 50%;
margin: 0px 5px;
animation: anim 2s infinite cubic-bezier(.48, .06, .44, .82);
}
.anim div:nth-child(1) {
animation-delay: 0s;
background-color: rgb(190, 196, 255);
}
.anim div:nth-child(2) {
animation-delay: .15s;
background-color: rgb(138, 149, 255);
}
.anim div:nth-child(3) {
animation-delay: .3s;
background-color: rgb(92, 108, 255);
}
.anim div:nth-child(4) {
animation-delay: .45s;
background-color: rgb(53, 73, 255);
}
@keyframes anim {
0% {
transform: translateY(0px);
}
45% {
transform: translateY(-15px);
}
100% {
transform: translateY(0px);
}
}
É literalmente copiar e colar, e o loader estará prontinho!
Esse é um loader que cobre a tela inteira, que você pode usar em situações onde o usuário muda de página mas as informações da página nova ainda não foram totalmente carregadas.
Porém, é possível retirar esse plano de fundo que cobre a tela toda e usar somente a parte da animação de forma separada, se você preferir!
Também é possível aumentar ou diminuir o tamanho dos círculos através da width e heigth nesse trecho de código:
.anim div {
width: 12px;
height: 12px;
border-radius: 50%;
margin: 0px 5px;
animation: anim 2s infinite cubic-bezier(.48, .06, .44, .82);
}
Você também pode mudar as cores de acordo com sua preferência, de todos os círculos ou de cada um individualmente, como eu fiz. Basta apenas alterar o background-color de cada div.
Espero muito que isso seja útil para alguém!