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

BoC*_*edy 3 html javascript css3 flip

好的,所以我对编写Javascript知之甚少,我可以稍微编辑一下,并且在CSS3动画中有点涉及.

我会给你一个我想要实现的东西的形象,然后在下面解释.

网站布局如下:http://i.imgur.com/XyhaxNP.jpg

我已经在Google上找到了一些方法,但是当用户将鼠标悬停在div上时,他们中的大多数似乎都会翻转div,我需要将它放在点击事件上,因为它还需要在移动设备上运行.

带有切换按钮的第三个演示就是我所看到的,但是当我将事件添加到图像时,这似乎不起作用.

这是我到目前为止,我已将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>
Run Code Online (Sandbox Code Playgroud)

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);
}
Run Code Online (Sandbox Code Playgroud)

所以在这个当前点,当你将鼠标悬停在它上面时,它会翻转,当你点击图像时我只需要翻转它.

这是一个有效的演示:http://jsfiddle.net/wvveY/1/

Mar*_*rib 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>
Run Code Online (Sandbox Code Playgroud)

然后你有CSS类:

.flipped {
  -webkit-transform:rotateY(180deg);
  -moz-transform:rotateY(180deg);
  -ms-transform:rotateY(180deg);
  -o-transform:rotateY(180deg);
  transform:rotateY(180deg);
}
Run Code Online (Sandbox Code Playgroud)

看到它在这里工作:http://jsfiddle.net/wvveY/4/