3

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

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/

4

2 回答 2

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/

于 2013-07-24T11:26:49.630 回答
0

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

让它.flip-container:active代替.flip-container:hover

于 2013-07-24T11:10:00.553 回答