【发布时间】:2016-06-25 18:49:43
【问题描述】:
所以基本上我想用 div 创建一种门效果
单击按钮时打开和关闭。
var buttons = document.querySelectorAll('button');
[].forEach.call(buttons, function(btn) {
btn.addEventListener('click', function(e) {
var target = e.target;
if (target.nodeName.toLowerCase() === 'button') {
document.getElementById(target.dataset.target + '-div').className = target.textContent === 'stop' ? '' : target.textContent;
}
});
});
button {
height: 24px;
font-size: 16px;
}
div {
position: relative;
left: 0;
margin-left: 0;
padding-left: 0;
transform: none;
margin-top: 10px;
width: 200px;
height: 200px;
border: 0 white solid;
background-color: green;
}
#transition-div {
transition: transform 1s ease-in-out;
}
#transition-div.start {
transform: translateX(400px);
}
@keyframes move-right {
0% { transform: translateX(0px); }
50% { transform: translateX(400px); }
100% { transform: translateX(0px); }
}
<section>
<h1>Transition</h1>
<button data-target="transition">start</button>
<button data-target="transition">stop</button>
<div id="transition-div"></div>
</section>
可以在纯 CSS 中创建顶部结果还是必须在网页中实现 javascript? 您能否将“开始”和“停止”按钮合并为一个按钮? 伙计们干杯!
【问题讨论】:
-
看看这个帖子 - stackoverflow.com/questions/33347992/… 您正在寻找非常相似的东西(即在第二次单击或第二个按钮单击时播放反向动画)。
-
以上评论是基于假设您正在尝试为“动画”元素执行此操作。如果您只是想使用 CSS 来实现这种效果,那么应该可以使用过渡来实现。