好的,所以我对编写Javascript知之甚少,我可以稍微编辑一下,并且在CSS3动画中有点涉及。
我会给你一张我想要实现的东西的形象,然后在下面解释。
网站布局如下:http://i.imgur.com/XyhaxNP.jpg
我已经找到了一些在Google上进行此操作的方法,但是当用户将鼠标悬停在div上时,他们中的大部分似乎都会翻转div,我需要将其作为点击事件,因为它还需要在移动设备上运行。< / p>
带有切换按钮的第三个演示是我所看到的,但是当我将事件添加到图像时,这似乎不起作用。
这是我到目前为止,我已经将onclick事件移动到图像(它曾经在我找到的演示中的按钮上)但它对图像不起作用。
HTML:
<div class="flip-container">
<div class="flipper">
<div class="front">
<img class="teamlogo" onclick="document.querySelector('#flip-toggle').classList.toggle('flip');" src="images/logo/niners.png"/>
</div>
<div class="back">
Back of div content
</div>
</div>
</div>
CSS:
.teamlogo{
padding-left: 5%;
}
/* 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;
}
/* back, initially hidden pane */
.back {
transform: rotateY(180deg);
}
所以在这个当前点,当你将鼠标悬停在它上面时它会翻转,当你点击图像时我只需要翻转它。
这是一个有效的演示:http://jsfiddle.net/wvveY/1/
答案 0 :(得分:5)
通常,您希望将JavaScript与HTML分开,但如果您希望将其放在标记内,那么最好放置代码引用的标记,即标记。这样,该div内的任何点击,无论是图像还是文本,都会触发翻转。
<div class="flip-container">
<div class="flipper" onclick="this.classList.toggle('flipped')">
<div class="front">
Front
</div>
<div class="back">
Back
</div>
</div>
</div>
然后你有CSS类:
.flipped {
-webkit-transform:rotateY(180deg);
-moz-transform:rotateY(180deg);
-ms-transform:rotateY(180deg);
-o-transform:rotateY(180deg);
transform:rotateY(180deg);
}
看到它在这里工作:http://jsfiddle.net/wvveY/4/
答案 1 :(得分:0)
将其设为.flip-container:active
而不是.flip-container:hover