如何用纯JavaScript制作淡出效果

bakd9h0s  于 2023-01-24  发布在  Java
关注(0)|答案(8)|浏览(182)

我正在尝试用***纯JavaScript***为div制作淡出效果。
这是我目前正在使用的:

//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

r7s23pms

r7s23pms1#

最初,当没有设置不透明度时,该值将是一个空字符串,这将导致运算失败,即"" < 0.1 == true,您的代码将进入clearInterval分支。
您可以将其默认为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 transitions以更少的代码实现淡出
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>
mo49yndu

mo49yndu2#

就在今天早上,我在http://vanilla-js.com上找到了这段代码,它非常简单、紧凑和快速:

var s = document.getElementById('thing').style;
s.opacity = 1;
(function fade(){(s.opacity-=.1)<0?s.display="none":setTimeout(fade,40)})();

您可以通过更改setTimeOut函数中的第二个参数来更改渐变速度。
x一个一个一个一个x一个一个二个一个x一个一个三个一个

js81xvg6

js81xvg63#

看起来你可以用另一种方法来做(我可能错了)。

event.target.style.transition = '0.8s';
event.target.style.opacity = 0;
ohfgkhjo

ohfgkhjo4#

你可以使用CSS转换属性而不是在javascript中使用vai定时器。与你正在做的相比,这更注重性能。
核对
http://fvsch.com/code/transition-fade/test5.html#test3

ht4b089n

ht4b089n5#

除了公认的答案之外,我们现在还有WAAPI,它基本上是将动画API添加到JavaScript中。
例如,

/**
 * @returns {Object}
*/
function defaultFadeConfig() {
  return {      
      easing: 'linear', 
      iterations: 1, 
      direction: 'normal', 
      fill: 'forwards',
      delay: 0,
      endDelay: 0
    }  
}

/** 
 * @param {HTMLElement} el
 * @param {number} durationInMs
 * @param {Object} config
 * @returns {Promise}
 */
async function fadeOut(el, durationInMs, config = defaultFadeConfig()) {  
  return new Promise((resolve, reject) => {         
    const animation = el.animate([
      { opacity: '1' },
      { opacity: '0', offset: 0.5 },
      { opacity: '0', offset: 1 }
    ], {duration: durationInMs, ...config});
    animation.onfinish = () => resolve();
  })
}

/** 
 * @param {HTMLElement} el
 * @param {number} durationInMs
 * @param {Object} config
 * @returns {Promise}
 */
async function fadeIn(el, durationInMs, config = defaultFadeConfig()) {
  return new Promise((resolve) => {         
    const animation = el.animate([
      { opacity: '0' },
      { opacity: '0.5', offset: 0.5 },
      { opacity: '1', offset: 1 }
    ], {duration: durationInMs, ...config});
    animation.onfinish = () => resolve();
  });
}

window.addEventListener('load', async ()=> {
  const el = document.getElementById('el1');  
  for(const ipsum of "Neque porro quisquam est qui dolorem ipsum quia dolor \uD83D\uDE00".split(' ')) {
    await fadeOut(el, 1000);  
    el.innerText = ipsum;
    await fadeIn(el, 2000);
  }
});
.text-center {
  text-align: center;
}
<h1 id="el1" class="text-center">...</h1>
rkue9o1l

rkue9o1l6#

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>
nfs0ujit

nfs0ujit7#

我的解决方案

function fadeOut(selector, timeInterval, callback = null) {

    var fadeTarget = document.querySelector(selector);

    let time = timeInterval / 1000;
    fadeTarget.style.transition = time + 's';
    fadeTarget.style.opacity = 0;
    var fadeEffect = setInterval(function() {

        if (fadeTarget.style.opacity <= 0)
        {
            clearInterval(fadeEffect);
            if (typeof (callback) === 'function') {
                callback();
            }
        }
    }, timeInterval);
}
tkclm6bt

tkclm6bt8#

虽然这个和其他SO线程中的大多数解决方案都能工作,但这里我有两分钱。如果你只想依赖纯JS,那么这应该可以做到:

function fadeOutEle(el) {
        el.style.opacity = 1;
        (function fade() {
            if ((el.style.opacity -= .009) < 0) {
                el.style.display = "none";
            } else {
                requestAnimationFrame(fade);
            }
        })();
    };

这里的关键是el.style.opacity -= .009,它给予一个很酷的淡出效果。保持它在1/2秒以下(本例中为0.009),这样效果在元素隐藏之前就可以看到。

相关问题