[英]How can I trigger this :hover flip effect with jQuery?
This code works like a charm to flip a div: 这段代码就像翻转div的符咒一样工作:
view 视图
<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
<div class="flipper">
<div class="front">
FLIP ME
</div>
<div class="back">
FLIP ME AGAIN
</div>
</div>
css CSS
/* entire container, keeps perspective */
.flip-container {
perspective: 1000;
}
/* flip the pane when hovered */
.flip-container:hover .flipper, .flip-container.hover .flipper {
transform: rotateY(180deg);
}
.flip-container, .front, .back {
width: 320px;
height: 480px;
}
/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;
position: relative;
}
/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;
position: absolute;
top: 0;
left: 0;
}
/* front pane, placed above back */
.front {
z-index: 2;
/* for firefox 31 */
transform: rotateY(0deg);
}
/* back, initially hidden pane */
.back {
transform: rotateY(180deg);
}
But it flips when I hover over the div. 但是当我将鼠标悬停在div上时,它就会翻转。 I would like for it to flip only when I click on it, and keep flipping once every time I click.
我希望它仅在单击时才能翻转,并在每次单击时保持翻转一次。 There doesn't appear to be an
:onclick
method in CSS. CSS中似乎没有
:onclick
方法。 Is there a way I can use jQuery to trigger the CSS above? 有没有一种方法可以使用jQuery触发上述CSS?
I finally figured out a very simple solution. 我终于找到了一个非常简单的解决方案。 All I had to do was remove the :hover method and then toggle the class:
我要做的就是删除:hover方法,然后切换类:
html HTML
<div id="flip-container" ontouchstart="this.classList.toggle('hover');">
<div class="flipper">
<div class="front">
FLIP ME
</div>
<div class="back">
FLIP ME AGAIN
</div>
</div>
</div>
css CSS
#flip-container {
width: 320px;
height: 480px;
}
.flip-container {
perspective: 1000;
}
.flip-container .flipper, .flip-container .flipper {
transform: rotateY(180deg);
}
.flip-container, .front, .back {
width: 320px;
height: 480px;
}
.flipper {
transition: 0.6s;
transform-style: preserve-3d;
position: relative;
}
.front, .back {
backface-visibility: hidden;
position: absolute;
top: 0;
left: 0;
}
.front {
z-index: 2;
/* for firefox 31 */
transform: rotateY(0deg);
}
.back {
transform: rotateY(180deg);
}
js JS
$("#flip-container").click(function() {
$(this).toggleClass("flip-container");
});
You could use :active or :target to get the effect you're looking for. 您可以使用:active或:target获得所需的效果。 Look at this thread: Can I have an onclick effect in CSS?
看一下这个线程: 我可以在CSS中产生onclick效果吗?
Off the top of my head you'll need to a click event with a timer as well. 在我的头顶上,您还需要带有计时器的click事件。
javaScript 的javaScript
var myTimerForFlip,
myFlipTime = 600;
$('.flip-container').click(function(){
stopMyFlip(); //reset the animation
$(this).addClass('animatingflip'); //add animation class
myTimerForFlip = setTimeout(removeFlip , myFlipTime); //start up timer again
});
var removeFlip = function (){
$('.animatingflip').removeClass('animatingflip');
};
function stopMyFlip () {
clearTimeout(myTimerForFlip);
}
New CSS 新CSS
/* flip the pane when hovered */
.animatingflip .flipper, .animatingflip .flipper {
transform: rotateY(180deg);
}
So basically, add a class > animation happens. 因此,基本上,添加类>动画会发生。 Then after .6s remove the class.
然后在.6s之后删除该类。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.