28 diciembre, 2020
Para crear tarjetas animadas en 3d con Javascript, CSS y HTML usaremos animaciones con keyframes y js para la interactividad en el evento mouseover.
Suscríbete a nuestro canal en Youtube
SuscríbirseEl efecto Glass Morphism este 2021 es probable que se vuelva una tendencia se trata de usar transparencias muy acentuadas con difuminado de border haciendo la comparación con un vidrio. Dicho esto pues veamos este efecto aplicado a una tarjeta
Veamos como implementarlo con JAVASCRIPT VAINILLA, HTML Y CSS.
La hoja de estilos
<style>
body{
margin: 0;
background-size: cover;
display: grid;
place-items: center;
font-family: Arial, Helvetica, sans-serif;
color: white;
min-height: 100vh;
perspective: 1000px;
background-color: tomato;
}
.container{
width: 100%;
display: flex;
justify-content: center;
}
.card{
transform-style: preserve-3d;
background: linear-gradient(rgba(255, 255, 255, 0.1),rgba(255, 255, 255, 0.105));
border-top: 1px solid rgba(255, 255, 255, 0.5);
border-left: 1px solid rgba(255, 255, 255, 0.5);
min-height: 60vh;
width: 33%;
margin: 50px;
border-radius: 20px;
color: white;
box-shadow: 0 20px 50px rgba(0, 0, 0, 0.466);
place-items: center;
display: grid;
transition: all 0.75s ease;
}
.card::after{
content: '';
position: absolute;
border-radius: 20px;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: linear-gradient(rgba(76, 0, 130, 0.726), rgb(19, 0, 128));
clip-path: circle(30% at 10% 5%);
}
.title{
transition: all 0.75s ease-out;
font-family: 'Anton', sans-serif;
background: crimson;
padding: 50px;
border-radius: 10px;
}
@keyframes animacion {
0%{ background: rgba(76, 0, 130, 0) ;}
100%{ background: rgb(76, 0, 130) ;}
}
.btn{
border-radius: 30px;
background-color: indigo;
color: white;
padding: 10px 30px 10px 30px;
text-decoration: none;
}
.contenido__video{
background: #7DD174;
overflow: hidden;
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: -1;
}
video {
object-fit: cover;
width: 100vw;
height: 100vh;
top: 0;
left: 0;
}
</style>
Ahora el Html
<div class="contenido__video">
<video src="video.mp4" autoplay loop muted >
<source src="video.mp4" type="video/mp4">
</video>
</div>
<H1>DESARROLLO WEB</H1>
<div class="container">
<div class="card">
<div class="title">
<h1>FRONTEND </h1>
</div>
<a href="" class="btn">INTRO</a>
</div>
<div class="card">
<div class="title">
<h1>BACKEND </h1>
</div>
<a href="" class="btn">INTRO</a>
</div>
<div class="card">
<div class="title">
<h1>FULLSTACK </h1>
</div>
<a href="" class="btn">INTRO</a>
</div>
</div>
Finalmente el código Javascript
const container = document.querySelectorAll(".container .card")
container.forEach(el => {
el.addEventListener("mousemove",(e)=> {
let xAxis = (window.innerWidth/2-e.pageX)/15
let yAxis = (window.innerHeight/2-e.pageY)/15
el.style.transform =`rotateY(${xAxis}deg) rotateX(${yAxis}deg)`
})
})
//in
container.forEach(el => {
el.addEventListener('mouseenter',(e)=>{
el.style.transition =`all 0.5s ease`
el.style.animation =`animacion 1.5s forwards`
el.querySelector(".title").style.transform ="translateZ(150px)"
})
})
//out
container.forEach(el => {
el.addEventListener('mouseleave',(e)=>{
el.style.transition =`all 1.5s ease`
el.style.animation =`none`
el.style.transform =`rotateY(0deg) rotateX(0deg)`
el.querySelector(".title").style.transform ="translateZ(0px)"
})
})
Hasta otro tutorial
Leido 5448 veces
© Copyright Codea App | LATAM | 2020 - 2024