0

如何使用 CSS3 动画应用多个变换?

这是我的 HTML 代码:

<div class="container">
<div class="cell"><span class="inner"></span><span class="inner"></span></div>
<div class="cell"><span class="inner"></span><span class="inner"></span></div>
<div class="cell"><span class="inner"></span><span class="inner"></span></div>
<div class="cell"><span class="inner"></span><span class="inner"></span></div>
<div class="cell"><span class="inner"></span><span class="inner"></span></div>
</div>

我的尝试:

@-webkit-keyframes firstanim{
    from{
        -webkit-transform:scale(1);
        -webkit-transform:rotate(0deg);
    backgroud:skyblue;
    left:0px;

    -webkit-transform: rotateY(0deg);
   }    to{
    -webkit-transform:rotate(360deg);
    -webkit-transform:scale(1.5);
    background:orange;
    left:100px;
    -webkit-transform: rotateY(360deg);
   }
}


.container{
    border:1px solid black;
    padding:20px;
    width:250px;
    height:50px;
    position:realtive;
}
.cell{
    width:25px;
    height:25px;

    background:skyblue;

    float:left;
    display:inline-block;
    margin:0px 5px;
    position:relative;
    -webkit-animation: firstanim 3s infinite;

}
.inner{
 width:100%;
 height:50%;
 float:left;

    border:1px solid white;
    border-left-width:0px;
    borer-right-width:0px;
}

结果位于此处

即使我添加了更多,也只对元素应用了一种变换。

4

2 回答 2

5

如果你写这样的东西:

transform: rotate(30deg);
transform: scale(3);

然后第二个覆盖第一个,并且您的元素仅缩放,不旋转。

为了将多个转换应用于单个元素,您需要将它们链接起来。

例子:

transform: rotate(30deg) scale(3) translateX(3em) skewY(60deg);

此外,应用它们的顺序很重要,根据选择的顺序,您可能会得到不同的结果 - 请参阅此示例,其中蓝色框在应用相同的两个变换后与红色框的形状不同,但在逆序。

您使用链式转换的小提琴:http: //jsfiddle.net/TBrf2/4/

于 2012-09-28T11:51:07.917 回答
2

这是使用多个转换的小提琴演示。

-webkit-transform:scale(1)  rotateY(0deg);

你需要像这样申请。

于 2012-09-28T11:56:00.760 回答