進入css3動畫世界(二)


進入css3動畫世界(二)

今天主要來講transition和transform入門,以后會用這兩種屬性配合做一些動效。

注:本文面向前端css3動畫入門人員,我對這個也了解不深,如本文寫的有紕漏請指出,不喜勿噴。

transition屬性

從中文翻譯來講,這是一個過渡屬性,而這個屬性的屬性值有四種:
transition: property duration timing-function delay
第一個是起作用的屬性名,第二個是動畫持續的時間,第三個是速度效果的曲線,第四個是過渡效果延遲多久后開始。
而我經常用的是第二個屬性值,其次是速度曲線。

下面我們用hover試下不同的效果:

**源碼:** ```html
改變寬度
持續3秒
勻速3秒
延遲1秒
```
.idiv{
    float: left;
    width: 100px;
    height: 100px;
    background: green;
    margin: 5px;
    font-size: 20px;
    color: #fff;
    line-height: 100px;
    text-align: center;
}
#change-width{
    transition: width 0.5s;
}
#change-width:hover{
    width: 300px;
}
#dur-3s{
    transition: 3s;
}
#dur-3s:hover{
    width: 300px;
}
#linear{
    transition: 0.5s linear;
}
#linear:hover{
    width: 300px;
}
#delay-1s{
    transition: 0.5s 1s;
}
#delay-1s:hover{
    width: 300px;
}

transform屬性

transform的意思是變換。

transform的變換很多,我可能沒那么深入去學,但是我們可以了解一下基本的幾種動畫:
translate(),rotate(),scale(),就憑這幾種基本的動畫加上你的想象力,就可以做出上一篇我們提到那頭大象了。當然,這些transform的屬性值最后還可以用一個屬性值matrix()完成,具體可以去膜拜一下張鑫旭關於matrix()的描述。

我們暫時只討論2d情況下的transform,當然還有一個skew()我沒怎么用過。

translate

translate()是平移,translateX(x)沿着x軸平移,translateY(y)沿着y軸平移,translate(x,y)沿着xy軸同時平移:

```html
div1 x平移
div2 y平移
div3 xy平移
```
.idiv{
    float: left;
    width: 100px;
    height: 100px;
    background: green;
    margin: 5px;
    font-size: 20px;
    color: #fff;
    line-height: 100px;
    text-align: center;
    transition: 0.5s;
}
#div1:hover{
    transform: translateX(20px);
}
#div2:hover{
    transform: translateY(20px);
}
#div3:hover{
    transform: translate(20px,20px);
}

rotate

rotate()是旋轉,2d的情況下,rotate()只接收一個角度作為參數。

<div class="idiv" id="rotate30">順時針旋轉30°</div>
<div class="idiv" id="rotate60">順時針旋轉60°</div>
<div class="idiv" id="rotate90">順時針旋轉90°</div>
<div class="idiv" id="rotate-30">逆時針旋轉30°</div>
<div class="idiv" id="rotate-60">逆時針旋轉60°</div>
<div class="idiv" id="rotate-90">逆時針旋轉90°</div>
.idiv{
    float: left;
    width: 100px;
    height: 100px;
    background: green;
    margin: 5px;
    font-size: 20px;
    color: #fff;
    line-height: 50px;
    text-align: center;
    transition: 0.5s;
}
#rotate30:hover{
    transform: rotate(30deg);
}
#rotate60:hover{
    transform: rotate(60deg);
}
#rotate90:hover{
    transform: rotate(90deg);
}
#rotate-30:hover{
    transform: rotate(-30deg);
}
#rotate-60:hover{
    transform: rotate(-60deg);
}
#rotate-90:hover{
    transform: rotate(-90deg);
}

scale()

scale()是縮放,和translate()一樣,接收1-2個參數。scaleX(x),scaleY(y),scale(x,y):

<div class="idiv" id="scalex">x軸放大到1.5倍</div>
<div class="idiv" id="scaley">y軸縮小到0.5倍</div>
<div class="idiv" id="scalexy">xy軸放大到2倍</div>
.idiv{
    float: left;
    width: 100px;
    height: 100px;
    background: green;
    margin: 5px;
    font-size: 20px;
    color: #fff;
    line-height: 50px;
    text-align: center;
    transition: 0.5s;
}
#scalex:hover{
    transform: scaleX(1.5);
}
#scaley:hover{
    transform: scaleY(0.5);
}
#scalexy:hover{
    transform: scale(2,2);
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM