我正在尝试制作淡出效果div
with 纯JavaScript.
这是我目前正在使用的:
//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);
}
div 应该平滑淡出,但它立即消失。
怎么了?我该如何解决?
jsbin
最初,当没有设置不透明度时,该值将为空字符串,这将导致算术失败。那是,"" < 0.1 == true
你的代码进入clearInterval
branch.
您可以将其默认为 1 并且它会起作用。
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>
在进行算术和比较时,空字符串似乎被 JavaScript 视为 0(即使在 CSS 中它将该空字符串视为完全不透明)
> '' < 0.1
> true
> '' > 0.1
> false
> '' - 0.1
> -0.1
更简单的方法我们现在可以使用CSS 过渡用更少的代码实现淡出
const target = document.getElementById("target");
target.addEventListener('click', () => target.style.opacity = '0');
// If you want to remove it from the page after the fadeout
target.addEventListener('transitionend', () => target.remove());
#target {
height: 100px;
background-color: red;
transition: opacity 1s;
}
<p>Some text before<p>
<div id="target">Click to fade</div>
<p>Some text after</p>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)