0

我正在寻找一种本机 JS 解决方案来使用 display:'none' 和 display:'block' 属性切换 div 显示。我已经完成了第一部分。我只需要这个部分来做一个简单的fadeIn 和fadeOut 动画。

我需要使用原生 JS 和 display:block,none。

var e = document.getElementById('calendarPickerContainer');

    if (e.className == 'visible') { 
        e.className = 'hidden';
    } else {
        e.className = 'visible';
    }

需要适应这个css

.visible{
display:block;
}

.hidden {
display:none;
}
4

4 回答 4

3

如果你想使用纯 JavaScriptfadeInfadeOut,试试这个:

transition: opacity 1s linear;

这是一个纯 CSS 方法。

#cont {-webkit-transition: opacity 1s linear; -o-transition: opacity 1s linear; transition: opacity 1s linear;}
#cont.hidden {opacity: 0;}
<button onclick="cont.classList.add('hidden'); setTimeout('cont.style.display=\'none\'', 1000);">Click</button>
<div id="cont">
  Hello
</div>

工作片段(包括切换):

#cont {-webkit-transition: opacity 1s linear; -o-transition: opacity 1s linear; transition: opacity 1s linear; opacity: 1;}
#cont.hidden {opacity: 0; -webkit-transition: opacity 1s linear; -o-transition: opacity 1s linear; transition: opacity 1s linear;}
<button onclick="if (cont.style.display != 'none') { cont.classList.add('hidden'); setTimeout('cont.style.display=\'none\'', 1000); } else {cont.style.display='block'; setTimeout('cont.classList.remove(\'hidden\')', 10);}">Click</button>
<div id="cont">
  Hello
</div>

于 2015-11-27T11:47:10.830 回答
0

您可以使用 CSS3 轻松实现这一点

.visible {
  visibility: visible;
  opacity: 1;
  transition: opacity 2s linear;
}
.hidden {
  visibility: hidden;
  opacity: 0;
  transition: visibility 0s 2s, opacity 2s linear;
}
于 2015-11-27T11:46:47.000 回答
0

原生 JS 淡入淡出功能:

var s = document.getElementById('calendarPickerContainer').style;
s.opacity = 1;
(function fade(){(s.opacity-=.1)<0?s.display="none":setTimeout(fade,40)})();
于 2015-11-27T11:50:25.063 回答
0

你可以简化这个classList

document.querySelector('.toggle').addEventListener('click',function(e) {
  e.target.classList.toggle('hide');
})

CSS:

div {
  transition:all 0.3s ease-in;
}

.hide {

  opacity: 0;
}

我们正在使用opacity,因为display无法设置动画。

例子

于 2015-11-27T11:53:07.653 回答