HTML、CSS製作翻牌效果

5/3   講者:Cuboid

Outline

  • HTML結構
  • 利用 CSS 達到翻牌
  • 完整程式碼
  • 參考資源

HTML結構

<div class="container"> 
   <div class="front">front</div>
   <div class="back">back</div>
</div>

利用CSS 達到翻牌

 step 1.

        body {
            height: 100vh;
            /*高度等於螢幕寬度*/
            /*垂直置中*/
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .container {
            width: 300px;
            height: 400px;
        }

        .front,
        .back {
            width: 100%;
            height: 100%;
            
        }

        .front {
          
            background-color: red;

        }

        .back {
            background-color: blue;
        }

設定container,front,back的長寬(長寬都一樣),並給上顏色

接著將物件垂直置中

step 1 做完長這樣

step 2.

將 front,back

用絕對定位重疊再一起

 	body {
            height: 100vh;
            /*高度等於螢幕寬度*/
            /*垂直置中*/
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .container {
            width: 300px;
            height: 400px;
            /*新增*/
            position: relative;
            /*-----*/
        }

        .front,
        .back {
            width: 100%;
            height: 100%;
            /*新增*/
            position: absolute;
            /*-----*/
        }

        .front { 
            background-color: red;
        }

        .back {
            background-color: blue;
        }

step 2 做完長這樣

先做到這樣 限時2分鐘

step 3-1

        .container {
            width: 300px;
            height: 400px;
            position: relative;
            /*新增*/
             perspective: 1000px; 
                /*立體透視深度,即是讓物件看起來有3D的感覺*/
                /*而perspective的值我們可以想像成物件距離螢幕的距離,如果值越大代表越遠。*/
                /*數值越小代表離螢幕越近,而越貼近則會有透視越強烈的感覺*/
            /*-----*/
        }

        .front,
        .back {
            width: 100%;
            height: 100%;
            position: absolute;
            /*新增*/
            backface-visibility: hidden; /*html 元素背後不可看見*/
            /*------*/
        }

        .front {
            background-color: red;
            /*新增*/
            transform: rotateY(0deg);
            /*-----*/
        }

        .back {
            background-color: blue;
            /*新增*/
            transform: rotateY(-180deg);/*設定-180deg即是將back翻到背面(背面看不到,因為設定了 backface-visibility: hidden;)*/
            /*------*/
        }

step 3-2    rotate

step 3 做完長這樣

step 4 翻牌動畫

.front,
.back {
	width: 100%;
	height: 100%;
	position: absolute;
	backface-visibility: hidden; /*html 元素背後不可看見*/
	/*新增*/
	transition: .8s; /*動畫時間 0.8秒*/
	/*------*/
        }

.front {
	background-color: red;
	transform: rotateY(0deg);        
        }

.back {
	background-color: blue;
	transform: rotateY(-180deg);/*設定-180deg即是將back翻到背面(背面看不到,因為設定了 backface-visibility: hidden;)*/
		}


.back {
	background-color: blue;	
	transform: rotateY(-180deg);/*設定-180deg即是將back翻到背面(背面看不到,因為設定了 backface-visibility: hidden;)*/
        }	
    
    
/*新增*/
.container:hover .front{
	transform: rotateY(180deg);/*當hover時,front從正面轉到背面*/
        }
.container:hover .back{
 	transform: rotateY(0deg);/*當hover時,back從背面轉到正面*/
        }
/*--------*/

完整css 程式碼

        body{
            height: 100vh;
            display: flex;
            justify-content: center;
            align-items: center;
           }
        .container{
            width: 300px;
            height: 400px;
            margin: auto;
            position: relative;
            perspective: 1000px; /*立體透視深度*/
        }
        .front,.back{
             width: 100%;
             height: 100%;
             position: absolute;
             backface-visibility: hidden; /*html 元素背後不可看見*/
             transition: .8s;
        }
        .front{
            transform: rotateY(0deg);
            background-color: red;
            
        }
        .back{  
            background-color: blue;
            transform: rotateY(-180deg);
           
        }
        .container:hover .front{
            transform: rotateY(180deg);
        } 
        .container:hover .back{
            transform: rotateY(0deg);
        }

完整

程式碼

<!DOCTYPE html>
<html class="no-js">
    <head>
        <meta charset="utf-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <title>flip card</title>
        <meta name="description" content="">
        <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        body{
            height: 100vh; /*高度等於螢幕寬度*/
            /*垂直置中*/
            display: flex;
            justify-content: center;
            align-items: center;
        }
        .container{
            width: 300px;
            height: 400px;
            position: relative;
            perspective: 1000px; /*立體透視深度*/
        }
        .front,.back{
            width: 100%;
            height: 100%;
            position: absolute; /*絕對定位 使兩個div重疊*/
            backface-visibility: hidden; /*html 元素背後不可看見*/
            transition: .8s; /*動畫時間 0.8秒*/
        }
        .front{
            transform: rotateY(0deg);
            background-color: red;
            
        }
        .back{  
            background-color: blue;
            transform: rotateY(-180deg);/*設定-180deg即是將back翻到背面(背面看不到,因為設定了 backface-visibility: hidden;)*/
           
        }
        .container:hover .front{
            transform: rotateY(180deg);/*當hover時,front從正面轉到背面*/
        } 
        .container:hover .back{
            transform: rotateY(0deg);/*當hover時,back從背面轉到正面*/
        } 
    </style>
    </head>

    <body>
        <div class="container"> 
            <div class="front">front</div>
            <div class="back">back</div>
        </div>    
    </body>
</html>

參考資源

Thanks!

利用CSS製作翻牌效果

By Hong di Chen

利用CSS製作翻牌效果

  • 1,253