当单击该div中的图像时,如何翻转Div?

时间:2013-07-24 10:53:54

标签: javascript css3 html flip

好的,所以我对编写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/

2 个答案:

答案 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)

http://jsfiddle.net/wvveY/3/

将其设为.flip-container:active而不是.flip-container:hover