Dans le monde de la conception Web, l’ajout d’animations attrayantes à vos boutons peut faire une différence significative dans l’interaction utilisateur et dans l’expérience utilisateur globale. Une animation populaire est l’animation du bouton « Commander maintenant », qui peut attirer l’attention des utilisateurs et les encourager à agir. Dans ce didacticiel, nous vous guiderons tout au long du processus de création d’une animation de bouton « Commander maintenant » simple mais élégante en utilisant HTML, CSS et JavaScript.
Quelques ressources : ajoutez votre fichier HTML
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.12.2/gsap.min.js" integrity="sha512–16esztaSRplJROstbIIdwX3N97V1+pZvV33ABoG1H2OyTttBxEGkTsoIVsiP1iaTtM8b3+hu2kB6pQ4Clr5yug==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
Commençons par configurer la structure HTML de base de notre bouton et de notre animation :
<button class="truck-button">
<span class="default">Complete Order</span>
<span class="success">
Order Placed
<svg viewbox="0 0 12 10">
<polyline points="1.5 6 4.5 9 10.5 1"></polyline>
</svg>
</span>
<div class="truck">
<div class="wheel"></div>
<div class="back"></div>
<div class="front"></div>
<div class="box"></div>
</div>
</button>
Dans cette structure HTML, nous incluons des liens vers un fichier CSS externe (« styles.css ») et un fichier JavaScript externe (« script.js »). Nous avons également un bouton avec la classe « order-button » et un onclick
attribut qui déclenche l’animation lorsque vous cliquez dessus.
Ensuite, stylisons notre bouton et créons l’apparence initiale :
.truck-button {
--color: #fff;
--background: #2b3044;
--tick: #16bf78;
--base: #0d0f18;
--wheel: #2b3044;
--wheel-inner: #646b8c;
--wheel-dot: #fff;
--back: #6d58ff;
--back-inner: #362a89;
--back-inner-shadow: #2d246b;
--front: #a6accd;
--front-shadow: #535a79;
--front-light: #fff8b1;
--window: #2b3044;
--window-shadow: #404660;
--street: #646b8c;
--street-fill: #404660;
--box: #dcb97a;
--box-shadow: #b89b66;
padding: 12px 0;
width: 172px;
cursor: pointer;
text-align: center;
position: relative;
border: none;
outline: none;
color: var(--color);
background: var(--background);
border-radius: var(--br, 5px);
-webkit-appearance: none;
-webkit-tap-highlight-color: transparent;
transform-style: preserve-3d;
transform: rotateX(var(--rx, 0deg)) translateZ(0);
transition: transform 0.5s, border-radius 0.3s linear var(--br-d, 0s);
}
.truck-button:before, .truck-button:after {
content: "";
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 6px;
display: block;
background: var(--b, var(--street));
transform-origin: 0 100%;
transform: rotateX(90deg) scaleX(var(--sy, 1));
}
.truck-button:after {
--sy: var(--progress, 0);
--b: var(--street-fill);
}
.truck-button .default,
.truck-button .success {
display: block;
font-weight: 500;
font-size: 14px;
line-height: 24px;
opacity: var(--o, 1);
transition: opacity 0.3s;
}
.truck-button .success {
--o: 0;
position: absolute;
top: 12px;
left: 0;
right: 0;
}
.truck-button .success svg {
width: 12px;
height: 10px;
display: inline-block;
vertical-align: top;
fill: none;
margin: 7px 0 0 4px;
stroke: var(--tick);
stroke-width: 2;
stroke-linecap: round;
stroke-linejoin: round;
stroke-dasharray: 16px;
stroke-dashoffset: var(--offset, 16px);
transition: stroke-dashoffset 0.4s ease 0.45s;
}
.truck-button .truck {
position: absolute;
width: 72px;
height: 28px;
transform: rotateX(90deg) translate3d(var(--truck-x, 4px), calc(var(--truck-y-n, -26) * 1px), 12px);
}
.truck-button .truck:before, .truck-button .truck:after {
content: "";
position: absolute;
bottom: -6px;
left: var(--l, 18px);
width: 10px;
height: 10px;
border-radius: 50%;
z-index: 2;
box-shadow: inset 0 0 0 2px var(--wheel), inset 0 0 0 4px var(--wheel-inner);
background: var(--wheel-dot);
transform: translateY(calc(var(--truck-y) * -1px)) translateZ(0);
}
.truck-button .truck:after {
--l: 54px;
}
.truck-button .truck .wheel,
.truck-button .truck .wheel:before {
position: absolute;
bottom: var(--b, -6px);
left: var(--l, 6px);
width: 10px;
height: 10px;
border-radius: 50%;
background: var(--wheel);
transform: translateZ(0);
}
.truck-button .truck .wheel {
transform: translateY(calc(var(--truck-y) * -1px)) translateZ(0);
}
.truck-button .truck .wheel:before {
--l: 35px;
--b: 0;
content: "";
}
.truck-button .truck .front,
.truck-button .truck .back,
.truck-button .truck .box {
position: absolute;
}
.truck-button .truck .back {
left: 0;
bottom: 0;
z-index: 1;
width: 47px;
height: 28px;
border-radius: 1px 1px 0 0;
background: linear-gradient(68deg, var(--back-inner) 0%, var(--back-inner) 22%, var(--back-inner-shadow) 22.1%, var(--back-inner-shadow) 100%);
}
.truck-button .truck .back:before, .truck-button .truck .back:after {
content: "";
position: absolute;
}
.truck-button .truck .back:before {
left: 11px;
top: 0;
right: 0;
bottom: 0;
z-index: 2;
border-radius: 0 1px 0 0;
background: var(--back);
}
.truck-button .truck .back:after {
border-radius: 1px;
width: 73px;
height: 2px;
left: -1px;
bottom: -2px;
background: var(--base);
}
.truck-button .truck .front {
left: 47px;
bottom: -1px;
height: 22px;
width: 24px;
-webkit-clip-path: polygon(55% 0, 72% 44%, 100% 58%, 100% 100%, 0 100%, 0 0);
clip-path: polygon(55% 0, 72% 44%, 100% 58%, 100% 100%, 0 100%, 0 0);
background: linear-gradient(84deg, var(--front-shadow) 0%, var(--front-shadow) 10%, var(--front) 12%, var(--front) 100%);
}
.truck-button .truck .front:before, .truck-button .truck .front:after {
content: "";
position: absolute;
}
.truck-button .truck .front:before {
width: 7px;
height: 8px;
background: #fff;
left: 7px;
top: 2px;
-webkit-clip-path: polygon(0 0, 60% 0%, 100% 100%, 0% 100%);
clip-path: polygon(0 0, 60% 0%, 100% 100%, 0% 100%);
background: linear-gradient(59deg, var(--window) 0%, var(--window) 57%, var(--window-shadow) 55%, var(--window-shadow) 100%);
}
.truck-button .truck .front:after {
width: 3px;
height: 2px;
right: 0;
bottom: 3px;
background: var(--front-light);
}
.truck-button .truck .box {
width: 13px;
height: 13px;
right: 56px;
bottom: 0;
z-index: 1;
border-radius: 1px;
overflow: hidden;
transform: translate(calc(var(--box-x, -24) * 1px), calc(var(--box-y, -6) * 1px)) scale(var(--box-s, 0.5));
opacity: var(--box-o, 0);
background: linear-gradient(68deg, var(--box) 0%, var(--box) 50%, var(--box-shadow) 50.2%, var(--box-shadow) 100%);
background-size: 250% 100%;
background-position-x: calc(var(--bx, 0) * 1%);
}
.truck-button .truck .box:before, .truck-button .truck .box:after {
content: "";
position: absolute;
}
.truck-button .truck .box:before {
content: "";
background: rgba(255, 255, 255, 0.2);
left: 0;
right: 0;
top: 6px;
height: 1px;
}
.truck-button .truck .box:after {
width: 6px;
left: 100%;
top: 0;
bottom: 0;
background: var(--back);
transform: translateX(calc(var(--hx, 0) * 1px));
}
.truck-button.animation {
--rx: -90deg;
--br: 0;
}
.truck-button.animation .default {
--o: 0;
}
.truck-button.animation.done {
--rx: 0deg;
--br: 5px;
--br-d: 0.2s;
}
.truck-button.animation.done .success {
--o: 1;
--offset: 0;
}html {
box-sizing: border-box;
-webkit-font-smoothing: antialiased;
}
* {
box-sizing: inherit;
}
*:before, *:after {
box-sizing: inherit;
}
body {
min-height: 100vh;
display: flex;
font-family: "Inter UI", "Inter", Arial;
justify-content: center;
align-items: center;
background: #eceffc;
}
body .dribbble {
position: fixed;
display: block;
right: 20px;
bottom: 20px;
}
body .dribbble img {
display: block;
height: 28px;
}
body .twitter {
position: fixed;
display: block;
right: 64px;
bottom: 14px;
}
body .twitter svg {
width: 32px;
height: 32px;
fill: #1da1f2;
}
Dans ce code CSS, nous stylisons le bouton avec un fond bleu et du texte blanc. Lorsqu’on le survole, la couleur d’arrière-plan du bouton change légèrement pour lui donner une subtile sensation interactive.
Créons maintenant l’animation JavaScript pour rendre notre bouton « Commander maintenant » plus attrayant :
document.querySelectorAll('.truck-button').forEach(button => {
button.addEventListener('click', e => {e.preventDefault();
let box = button.querySelector('.box'),
truck = button.querySelector('.truck');
if(!button.classList.contains('done')) {
if(!button.classList.contains('animation')) {
button.classList.add('animation');
gsap.to(button, {
'--box-s': 1,
'--box-o': 1,
duration: .3,
delay: .5
});
gsap.to(box, {
x: 0,
duration: .4,
delay: .7
});
gsap.to(button, {
'--hx': -5,
'--bx': 50,
duration: .18,
delay: .92
});
gsap.to(box, {
y: 0,
duration: .1,
delay: 1.15
});
gsap.set(button, {
'--truck-y': 0,
'--truck-y-n': -26
});
gsap.to(button, {
'--truck-y': 1,
'--truck-y-n': -25,
duration: .2,
delay: 1.25,
onComplete() {
gsap.timeline({
onComplete() {
button.classList.add('done');
}
}).to(truck, {
x: 0,
duration: .4
}).to(truck, {
x: 40,
duration: 1
}).to(truck, {
x: 20,
duration: .6
}).to(truck, {
x: 96,
duration: .4
});
gsap.to(button, {
'--progress': 1,
duration: 2.4,
ease: "power2.in"
});
}
});
}
} else {
button.classList.remove('animation', 'done');
gsap.set(truck, {
x: 4
});
gsap.set(button, {
'--progress': 0,
'--hx': 0,
'--bx': 0,
'--box-s': .5,
'--box-o': 0,
'--truck-y': 0,
'--truck-y-n': -26
});
gsap.set(box, {
x: -24,
y: -6
});
}
});
});
En combinant HTML, CSS et JavaScript, nous avons créé une élégante animation de bouton « Commander maintenant » qui améliore non seulement l’interaction de l’utilisateur, mais ajoute également une touche d’interactivité à votre site Web. N’hésitez pas à personnaliser les couleurs, les tailles et la durée de l’animation en fonction du design et de l’image de marque de votre site Web. Expérimentez avec différentes animations pour créer des boutons uniques et attrayants dont vos utilisateurs pourront profiter.
to medium.com
Abonnez-vous à notre page Facebook: https://www.facebook.com/mycamer.net
Pour recevoir l’actualité sur vos téléphones à partir de l’application Telegram cliquez ici: https://t.me/+KMdLTc0qS6ZkMGI0
Nous ecrire par Whatsapp : Whatsapp +44 7476844931