我試圖使用過渡創建此效果。它應該看起來像你打開一個盒子。僅使用CSS創建箱體翻蓋打開效果
有2個問題:
- 其中框關閉是一樣的,它打開的順序。無論如何,要按照開啓的相反順序關閉盒子,以便盒子以與關閉時相同的狀態返回?
- 綠色和黃色襟翼的末端在過渡期間因爲紅色和藍色襟翼而隱藏,因此它看起來不是3D。有沒有一種方法可以用3D方式顯示所有襟翼?
我寧願如果解決方案是純CSS的,不需要JavaScript。
#box {
position: relative;
top: 170px;
left: 170px;
width: 300px;
height: 300px;
border: 1px solid black;
perspective: 800px;
}
#flap1, #flap2, #flap3, #flap4 {
position: absolute;
}
#flap1 {
background-color: red;
width: 150px;
height: 300px;
z-index: 1;
transform-origin: 0 0;
transition: transform 1s;
}
#flap2 {
left: 150px;
background-color: blue;
width: 150px;
height: 300px;
z-index: 1;
transform-origin: 100% 0;
transition: transform 1s ease 0.3s;
}
#flap3 {
background-color: green;
width: 300px;
height: 150px;
transform-origin: 0 0;
transition: transform 1s ease 0.6s;
}
#flap4 {
background-color: yellow;
top: 150px;
width: 300px;
height: 150px;
transform-origin: 0 100%;
transition: transform 1s ease 0.9s;
}
#box:hover #flap1{
transform: rotateY(-170deg);
}
#box:hover #flap2{
transform: rotateY(170deg);
}
#box:hover #flap3{
transform: rotateX(170deg);
}
#box:hover #flap4{
transform: rotateX(-170deg);
}
<html>
<head>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div id="box">
<div id="flap1"></div>
<div id="flap2"></div>
<div id="flap3"></div>
<div id="flap4"></div>
</div>
</body>
</html>
1.我認爲你不能。只需添加其他課程或其他內容。 2。你可以使用css3 ['perspective'](http://www.w3schools.com/cssref/css3_pr_perspective.asp) –