J'essaie de créer un effet fadeOut pour une div
avec JavaScript pur.
C'est ce que j'utilise actuellement:
//Imagine I want to fadeOut an element with id = "target"
function fadeOutEffect()
{
var fadeTarget = document.getElementById("target");
var fadeEffect = setInterval(function() {
if (fadeTarget.style.opacity < 0.1)
{
clearInterval(fadeEffect);
}
else
{
fadeTarget.style.opacity -= 0.1;
}
}, 200);
}
La div devrait disparaître en douceur, mais elle disparaîtra immédiatement.
Qu'est-ce qui ne va pas? Comment puis-je le résoudre?
Initialement, lorsqu'il n'y a pas d'opacité définie, la valeur sera une chaîne vide, ce qui entraînera l'échec de votre calcul. Vous pouvez le définir par défaut sur 1 et cela fonctionnera.
function fadeOutEffect() {
var fadeTarget = document.getElementById("target");
var fadeEffect = setInterval(function () {
if (!fadeTarget.style.opacity) {
fadeTarget.style.opacity = 1;
}
if (fadeTarget.style.opacity > 0) {
fadeTarget.style.opacity -= 0.1;
} else {
clearInterval(fadeEffect);
}
}, 200);
}
document.getElementById("target").addEventListener('click', fadeOutEffect);
#target {
height: 100px;
background-color: red;
}
<div id="target">Click to fade</div>
Une chaîne vide semble être traitée comme un 0 par JavaScript lors de l’arithmétique et des comparaisons (même si en CSS, cette chaîne vide est traitée comme une opacité totale)
> '' < 0.1
> true
> '' > 0.1
> false
> '' - 0.1
> -0.1
Ce matin même, j'ai trouvé ce code sur http://Vanilla-js.com , c'est très simple, compact et rapide:
var s = document.getElementById('thing').style;
s.opacity = 1;
(function fade(){(s.opacity-=.1)<0?s.display="none":setTimeout(fade,40)})();
Vous pouvez modifier la vitesse du fondu en modifiant le deuxième paramètre de la fonction setTimeOut
.
var s = document.getElementById('thing').style;
s.opacity = 1;
(function fade(){(s.opacity-=.1)<0?s.display="none":setTimeout(fade,40)})();
#thing {
background: red;
line-height: 40px;
}
<div id="thing">I will fade...</div>
vous pouvez utiliser la propriété de transition CSS plutôt que de faire vai timer en javascript. C’est plus orienté performance que ce que vous faites.
vérifier
var op = 1;
var element = document.getElementById('exitModal');
function closeModal() {
window.setInterval(function(){
element.style.opacity = op;
op = op - 0.01;
},10);