如何使用纯JavaScript制作fadeOut效果

Ana*_*in 27 javascript fadeout

我正试图div纯JavaScript制作fadeOut效果.

这就是我目前使用的:

//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);
}
Run Code Online (Sandbox Code Playgroud)

div应该顺利淡出,但它会立即消失.

怎么了?我该如何解决?

jsbin

Jua*_*des 39

最初,如果没有设置不透明度,则该值将为空字符串,这将导致算法失败.您可以将其默认为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);
Run Code Online (Sandbox Code Playgroud)
#target {
    height: 100px;
    background-color: red;
}
Run Code Online (Sandbox Code Playgroud)
<div id="target">Click to fade</div>
Run Code Online (Sandbox Code Playgroud)

在进行算术和比较时,一个空字符串似乎被JavaScript视为0(即使在CSS中它将该空字符串视为完全不透明)

> '' < 0.1
> true

> '' > 0.1
> false


> '' - 0.1
> -0.1
Run Code Online (Sandbox Code Playgroud)


Luc*_*ira 17

就在今天早上,我在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)})();
Run Code Online (Sandbox Code Playgroud)

您可以更改淡入淡出的速度,更改功能中的第二个参数setTimeOut.

var s = document.getElementById('thing').style;
s.opacity = 1;
(function fade(){(s.opacity-=.1)<0?s.display="none":setTimeout(fade,40)})();
Run Code Online (Sandbox Code Playgroud)
#thing {
  background: red;
  line-height: 40px;
}
Run Code Online (Sandbox Code Playgroud)
<div id="thing">I will fade...</div>
Run Code Online (Sandbox Code Playgroud)

  • @My1 不要缩小您在答案中发布的内容,而是让缩小器对生产代码执行此操作 (4认同)

Ale*_*nko 13

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

event.target.style.transition = '0.8s';
event.target.style.opacity = 0;
Run Code Online (Sandbox Code Playgroud)


Vik*_*ash 6

您可以使用 CSS 过渡属性,而不是在 javascript 中执行 vai 计时器。与您正在做的事情相比,这更注重性能。

查看

http://fvsch.com/code/transition-fade/test5.html#test3


Ale*_*sco 6

除了已接受的答案之外,我们现在还有WAAPI,它基本上向 JavaScript 添加了动画 API。

例如,

/**
 * @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);
  }
});
Run Code Online (Sandbox Code Playgroud)
.text-center {
  text-align: center;
}
Run Code Online (Sandbox Code Playgroud)
<h1 id="el1" class="text-center">...</h1>
Run Code Online (Sandbox Code Playgroud)