溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

CSS圖片翻轉(zhuǎn)動畫技術(shù)的詳細介紹

發(fā)布時間:2021-08-07 23:59:45 來源:億速云 閱讀:225 作者:chen 欄目:web開發(fā)

這篇文章主要講解了“CSS圖片翻轉(zhuǎn)動畫技術(shù)的詳細介紹”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“CSS圖片翻轉(zhuǎn)動畫技術(shù)的詳細介紹”吧!

CSS動畫非常的有趣;這種技術(shù)的美就在于,通過使用很多簡單的屬性,你能創(chuàng)建出就連皮克斯動畫制作公司也會贊嘆的漂亮的消隱效果。其中代表性的一種就是CSS圖片翻轉(zhuǎn)效果,能讓你看到一張卡片的正反兩面上的內(nèi)容。本文就是要用最簡單的方法向大家介紹如何創(chuàng)建這種效果。

簡單說明:這并不是第一篇我介紹這種技術(shù)的文章,但我發(fā)現(xiàn)那些都過于復(fù)雜了。網(wǎng)上還有很多其它的教材,但里面添加了很多多余的代碼樣式,需要讀者去分清哪些是必要的,那些是無用的;本文避免了這些問題,只列出了必要的CSS代碼,你可以在其上添加自己喜歡的風(fēng)格來美化這些卡片。

HTML代碼

實現(xiàn)正反面效果的HTML代碼,估計你也能想到應(yīng)該是這樣的:

代碼如下:


<div class="flip-container lazy " ontouchstart="this.classList.toggle('hover');">
<div class="flipper lazy ">
 <div class="front lazy ">
  <!-- 前面內(nèi)容 -->
 </div>
 <div class="back lazy ">
  <!-- 背面內(nèi)容 -->
 </div>
</div>
</div>

正如你想到的,應(yīng)該有兩個容器,分別存放卡片“前面”和“背面”,通過CSS,我們會指定這兩個容器元素自己的作用。還有需要注意的是ontouchstart這段js,它能讓你使用觸屏來觸發(fā)翻轉(zhuǎn)動作。顯然,你應(yīng)該把這段代碼單獨提取出來,讓JavaScript代碼放到一起。

CSS代碼

我敢打賭,你會感到驚訝,只需要如此少的代碼(如果不考慮各瀏覽器CSS方言前綴):

代碼如下:


/* entire container, keeps perspective */
.flip-container {
perspective: 1000;
}
/* flip the pane when hovered */
.flip-container:hover .flipper, .flip-container.hover .flipper {
 transform: rotateY(180deg);
}</p> <p>.flip-container, .front, .back {
width: 320px;
height: 480px;
}</p> <p>/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;</p> <p> position: relative;
}</p> <p>/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;</p> <p> position: absolute;
top: 0;
left: 0;
}</p> <p>/* front pane, placed above back */
.front {
z-index: 2;
}</p> <p>/* back, initially hidden pane */
.back {
transform: rotateY(180deg);
}

下面是大概的整個過程的原理:
1.在最外層的容器元素上設(shè)置整個動畫區(qū)域的透視(perspective)屬性。
2.當(dāng)外層容器元素遇到鼠標懸停事件時,內(nèi)部存放卡片的容器旋轉(zhuǎn)180度。這里也是控制旋轉(zhuǎn)速度的地方。如果將旋轉(zhuǎn)值設(shè)置為-180deg,是反向旋轉(zhuǎn)。
3.表示卡片正面和背面的元素都要絕對定位,這樣它們才能在相同的位置相互遮擋。它們的背面可視性(backface-visibility)屬性設(shè)置為隱藏,這樣每個卡片的背面在翻轉(zhuǎn)時都是看不見的。
4.將卡片的正面設(shè)置為一個比背面要高的z-index值,這樣保證卡片的正面在最上面。
5.將背面卡片旋轉(zhuǎn)180度,這樣讓它扮演背面的角色。
6.這就是全部這些代碼的作用!你把這段代碼放到你的網(wǎng)頁里,然后修飾一下卡片的樣式就行了!

來自CSS動畫專家Ana Tudor的提示

對卡片元素的某些屬性設(shè)置一些特定的值(例如)(like overflow: hidden)會導(dǎo)致其子元素喪失3D變換功能。我認可他的觀點,因為正是在本文的例子中我正好遇到了overflow: hidden相關(guān)的麻煩,它導(dǎo)致了3D變換子元素全都出現(xiàn)在了同一個平面上,有幾個是被旋轉(zhuǎn)了180度。

觸發(fā)CSS翻轉(zhuǎn)

如果你喜歡用JavaScript來觸發(fā)翻轉(zhuǎn)動作,下面這個簡單的css樣式類就能幫你做到這樣:

代碼如下:


.flip-container:hover .flipper, .flip-container.hover .flipper, .flip-container.flip .flipper {
transform: rotateY(180deg);
}

使用javascript給容器元素添加這個cssflip類就能觸發(fā)卡片翻轉(zhuǎn)&mdash;&mdash;不需要用戶懸停鼠標在上面。用document.querySelector("#myCard").classList.toggle("flip")實現(xiàn)它!

CSS豎向翻轉(zhuǎn)

執(zhí)行豎向翻轉(zhuǎn)也很簡單,跟橫向翻轉(zhuǎn)一樣,只需要修改一下 transform-origin的值,然后讓它按X軸旋轉(zhuǎn)。

代碼如下:


.vertical.flip-container {
position: relative;
}</p> <p> .vertical .back {
 transform: rotateX(180deg);
}</p> <p> .vertical.flip-container .flipper {
 transform-origin: 100% 213.5px; /* 高的一半 */
}</p> <p> .vertical.flip-container:hover .flipper {
 transform: rotateX(-180deg);
}

注意這里用的是rotateX,而不是之前的rotateY。

讓IE支持這種動畫技術(shù)

需要針對IE對這段標準的卡片翻轉(zhuǎn)代碼進行特殊的修改,因為IE還沒有實現(xiàn)現(xiàn)代瀏覽器中的transform功能?;镜淖龇ň褪菍φ婧捅趁鎯蓚€卡片同時分別翻轉(zhuǎn):

代碼如下:


/* entire container, keeps perspective */
.flip-container {
perspective: 1000;
transform-style: preserve-3d;
}
/*  UPDATED! flip the pane when hovered */
.flip-container:hover .back {
 transform: rotateY(0deg);
}
.flip-container:hover .front {
    transform: rotateY(180deg);
}</p> <p>.flip-container, .front, .back {
width: 320px;
height: 480px;
}</p> <p>/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;</p> <p> position: relative;
}</p> <p>/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;
transition: 0.6s;
transform-style: preserve-3d;</p> <p> position: absolute;
top: 0;
left: 0;
}</p> <p>/*  UPDATED! front pane, placed above back */
.front {
z-index: 2;
transform: rotateY(0deg);
}</p> <p>/* back, initially hidden pane */
.back {
transform: rotateY(-180deg);
}</p> <p>/*
Some vertical flip updates
*/
.vertical.flip-container {
position: relative;
}</p> <p> .vertical .back {
 transform: rotateX(180deg);
}</p> <p> .vertical.flip-container:hover .back {
    transform: rotateX(0deg);
}</p> <p> .vertical.flip-container:hover .front {
    transform: rotateX(180deg);
}

使用上面的這段代碼,IE10里也能正確的進行卡片翻轉(zhuǎn)了!

這個CSS卡片翻轉(zhuǎn)動畫技術(shù)一直是一個經(jīng)典的案例,代表著CSS動畫能夠?qū)崿F(xiàn)的效果,甚至3DCSS動畫能實現(xiàn)的強大效果。優(yōu)點就是使用的代碼很少很簡單。對于制作HTML5動畫來說這種效果非常的實用,可以說完美。你還能想到其它用到這個效果的地方嗎?

感謝各位的閱讀,以上就是“CSS圖片翻轉(zhuǎn)動畫技術(shù)的詳細介紹”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對CSS圖片翻轉(zhuǎn)動畫技術(shù)的詳細介紹這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI