CSS3
3D转换 - 导航栏特效
运行结果:
源码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}
ul {
margin: 200px;
}
ul li {
float: left;
width: 120px;
height: 40px;
margin: 0 10px;
list-style: none;
perspective: 500px;
}
.box {
position: relative;
width: 100%;
height: 100%;
/* 让子元素保持3D立体空间环境 */
transform-style: preserve-3d;
transition: all 0.6s;
cursor: pointer;
}
.box:hover {
transform: rotateX(90deg);
}
.front,
.bottom {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
text-align: center;
line-height: 40px;
color: #fff;
}
.front {
background-color: red;
z-index: 1;
transform: translateZ(20px);
}
.bottom {
background-color: #f40;
transform: translateY(20px) rotateX(-90deg);
}
</style>
</head>
<body>
<ul>
<li>
<div class="box">
<div class="front">艾欧尼亚</div>
<div class="bottom">欢迎你</div>
</div>
</li>
<li>
<div class="box">
<div class="front">艾欧尼亚</div>
<div class="bottom">欢迎你</div>
</div>
</li>
<li>
<div class="box">
<div class="front">艾欧尼亚</div>
<div class="bottom">欢迎你</div>
</div>
</li>
<li>
<div class="box">
<div class="front">艾欧尼亚</div>
<div class="bottom">欢迎你</div>
</div>
</li>
<li>
<div class="box">
<div class="front">艾欧尼亚</div>
<div class="bottom">欢迎你</div>
</div>
</li>
</ul>
</body>
</html>
参考资料:
[1] CSS3 3D转换 | 菜鸟教程
[2] transform-function | MDN