效果演示
Code
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>玻璃按钮</title>
<link href="https://cdn.bootcdn.net/ajax/libs/font-awesome/4.7.0/css/font-awesome.css" rel="stylesheet">
<link rel="stylesheet" href="./03-玻璃按钮.css">
</head>
<body>
<div class="container">
<div class="color"></div>
<div class="color"></div>
<div class="color"></div>
<ul>
<li>
<a href=""><i class="fa fa-qq" aria-hidden="true"></i></a>
</li>
<li>
<a href=""><i class="fa fa-weixin" aria-hidden="true"></i></a>
</li>
<li>
<a href=""><i class="fa fa-weibo" aria-hidden="true"></i></a>
</li>
<li>
<a href=""><i class="fa fa-tencent-weibo" aria-hidden="true"></i></a>
</li>
<li>
<a href=""><i class="fa fa-telegram" aria-hidden="true"></i></a>
</li>
</ul>
</div>
</body>
</html>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
.container {
position: absolute;
width: 100%;
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
background: linear-gradient(to bottom, #2193b0, #6dd5ed);
}
.container::before {
content: "";
position: absolute;
bottom: 0px;
width: 100%;
height: 50%;
z-index: 1;
border-top: 1px solid rgba(255, 255, 255, 0.5);
backdrop-filter: blur(5px);
}
.container .color {
position: absolute;
filter: blur(200px);
}
.container .color:nth-child(1) {
background: #2193b0;
width: 800px;
height: 800px;
top: -450px;
}
.container .color:nth-child(2) {
background: #2193b0;
width: 600px;
height: 600px;
bottom: -150px;
left: 100px;
}
.container .color:nth-child(3) {
background: #2193b0;
width: 400px;
height: 400px;
bottom: 50px;
right: 100px;
}
ul {
position: relative;
display: flex;
z-index: 2;
}
ul li {
position: relative;
list-style: none;
margin: 10px;
}
ul li a {
position: relative;
width: 80px;
height: 80px;
display: inline-block;
border-radius: 10px;
display: flex;
justify-content: center;
align-items: center;
text-decoration: none;
color: #fff;
font-size: 32px;
border: 1px solid rgba(255, 255, 255, 0.4);
border-right: 1px solid rgba(255, 255, 255, 0.2);
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
box-shadow: 0px 5px 45px rgba(0, 0, 0, 0.1);
backdrop-filter: blur(2px);
transition: all 0.5s;
overflow: hidden;
}
ul li a:hover {
transform: translateY(-20px);
}
ul li a::before {
content: "";
position: absolute;
top: 0px;
left: 0px;
width: 50px;
height: 100%;
background-color: #fff;
transform: skewX(45deg) translateX(150px);
transition: all 0.5s;
}
ul li a:hover::before {
transform: skewX(45deg) translateX(-150px);
}