【CSS动画05--闪亮的玻璃图标悬浮效果】

简介: 【CSS动画05--闪亮的玻璃图标悬浮效果】

image.png

闪亮的玻璃图标悬浮效果

介绍

代码

HTML

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
    <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="./css/5.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>

CSS

*{
    margin:0;
    padding:0;
    /* 这个是告诉浏览器:你想要设置的边框和内边距的值是包含在总宽高内的 */
    box-sizing: border-box;
}
.container{
    position: absolute;
    width: 100%;
    /* 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: #fd746c;
    width: 800px;
    height: 800px;
    top:-450px;
}
.container .color:nth-child(2){
    background: #cf8bf3;
    width: 600px;
    height: 600px;
    bottom: -150px;
    left: 100px;
}
.container .color:nth-child(3){
    background: #fdb99b;
    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{
    /* 鼠标移入元素沿Y轴上移 */
    transform: translateY(-20px);
}
/* 加个扫光动画 */
ul li a::before{
    content: "";
    position: absolute;
    top:0px;
    left:0px;
    width: 50px;
    height: 100%;
    background-color: #fff;
    /* 元素沿X轴45横切,沿X轴右移150px */
    transform: skewX(45deg) translateX(150px);
    /* 动画过渡 */
    transition: all 0.5s;
}
ul li a:hover::before{
    /* 元素沿X轴45横切,沿X轴左移150px */
    transform: skewX(45deg) translateX(-150px);
}
相关文章
|
1月前
|
机器学习/深度学习 前端开发 JavaScript
|
25天前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
102 58
|
4天前
|
Web App开发 前端开发 JavaScript
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
14 1
|
30天前
|
前端开发 JavaScript API
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
本文通过构建一个 3D 翻卡动画深入探讨了 CSS Houdini 的强大功能,展示了如何通过 Worklets、自定义属性、Paint API 等扩展 CSS 的能力,实现高度灵活的动画效果。文章首先介绍了 Houdini 的核心概念与 API,并通过构建一个动态星空背景、圆形进度条以及交互式 3D 翻卡动画的实际示例,展示了如何利用 CSS Houdini 赋予网页设计更多创造力。最后,还演示了如何将这种 3D 翻卡效果集成到公司网站中,提升用户体验。CSS Houdini 的创新能力为网页设计带来了前所未有的灵活性,推动了前端开发迈向新的高度。
26 0
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
|
2月前
|
前端开发
CSS实现闪亮效果
CSS实现闪亮效果
32 2
|
2月前
|
JavaScript 前端开发
JS配合CSS3实现动画和拖动小星星小Demo
本文通过代码示例展示了如何使用JavaScript和CSS3实现动画效果和拖动小星星的交互效果,包括文字掉落动画和鼠标拖动产生小星星动画的实现方法。
45 0
JS配合CSS3实现动画和拖动小星星小Demo
|
1月前
|
前端开发 Ubuntu Linux
CSS 修改鼠标图标样式
CSS 修改鼠标图标样式
37 0
|
1月前
|
前端开发
CSS 动画介绍及语法
CSS 动画介绍及语法
27 0
|
3月前
|
前端开发 UED 开发者
有趣的CSS - 文字加载动画效果
这个文本加载动画简单而有趣,可以在网站标题、广告标语或者关键信息的展示上吸引用户的注意力。开发者可以根据需要调整动画的持续时间、步骤数,或者光标颜色等,来适应特定的设计需求。使用这种动态元素,增强网站的互动性和用户体验,同时也为网站增添了一抹活泼的风格。
76 5
|
3月前
|
前端开发 JavaScript
HTML+CSS如何打造撒花动画效果?3分钟学会,炫酷到爆!
HTML+CSS如何打造撒花动画效果?3分钟学会,炫酷到爆!