用CSS来做一个动画案例

简介: 用CSS来做一个动画案例

今天来做这么一个案例



添加一个动画实现上下渐变滚动的效果


首先还是我们HTML部分,一个大盒子装着五个子元素


下面别在意,之前写的时候看到有个网站有这么个注解我就复制了下来哈哈哈


<div class="loader">
      <div class="slider" style="--i:0">
      </div>
      <div class="slider" style="--i:1">
      </div>
      <div class="slider" style="--i:2">
      </div>
      <div class="slider" style="--i:3">
      </div>
      <div class="slider" style="--i:4"> 
      </div>
    </div>
    <!-- keywords fixed by:lxl passed by:PTB ↑↑↑关键词也太多了,已经导致被k站了,修改了。-->
        <!-- wogiao 你没事为啥老来改网站?客户端bug后端内存溢出问题解决了?主机加速适配了?-->
        <!-- 管你屁事 -->
        <!-- keywords fixed by:wogaio passed by:PTB 修改关键词,现在应该不会被Ai误判了。--><!--new by:yjj 2023/1/25 wogiao那哥们骂我,**的,他的 经典 我给他保留了,美其名曰:节目效果-->
    <!-- 写网页前端的哥们,老子cnm,代码全部不格式化,上面喊你改也不改,老子开发客户端的跑来给你手动格式化,你是真特么nt,祝你早日滚蛋!下面写的sb滚动把图床快干废了,一天跑了3t流量你是真的牛逼,老子直接给你删了,都不想给你注释化,滚! by:wogiao 2022年11月25日 -->
    <!-- 
               ▃▆█▇▄▖
          ▟◤▖   ◥█▎
         ◢◤  ▐     ▐▉
      ▗◤   ▂ ▗▖  ▕█▎
     ◤ ▗▅▖◥▄ ▀◣  █▊
    ▐ ▕▎◥▖◣◤    ◢██
    █◣ ◥▅█▀    ▐██◤
    ▐█▙▂        ◢██◤
    ◥██◣    ◢▄◤
       ▀██▅▇▀
    哲学♂♂ 114514-->


第一步首先呢我们得让我们的大盒子设置一个弹性布局


让父元素水平垂直居中


.loader{
                display: flex;
                align-items: center;
                justify-content: center;


第二步我们来设置子元素


设置一个隐藏多余的样式,然后我们设置这个盒子宽高大小还有内外边距还有边框弧度加上内阴影弧度,最后设置一个相对定位,使他的子元素设置为据对定位


.slider{
                overflow: hidden;
                background-color: whitesmoke;
                border: 1px solid rgba(128,128,0.276);
                height: 80px;
                width: 20px;
                margin: 0 15px;
                border-radius: 30px;
                box-shadow: inset -5px -5px 10px #0000001a,
                inset -5px -5px 10px #0000001a;
                position: relative;
            }


第三步设置子元素的伪元素


content必不可少,因为这是一个主体,没有这个就没有内容,然后我们在继续设置绝对定位,置于左上角,然后设置宽高颜色,最后我们添加一个过渡方式,然后再下面我们来加动画


.slider::before{
                content: "";
                position: absolute;
                top: 0;
                left: 0;
                height: 80px;
                width: 20px;
                background: #2697f3;
                animation: alternate_2 2.5s ease-in-out infinite;
            }


第四步添加动画


@keyframes alternate_2{
                from{
                    transform: translateY(80px);
                    filter: hue-rotate(0deg);
                }
                50%{
                    transform: translateY(20px);
                }
                to{
                    transform: translateY(80px);
                    filter: hue-rotate(360deg);
                }
            }


from:开始的意思,然后沿着y轴上身80px


然后到五十的时候有沿着Y又下来20px


到百分比也就是to的时候就是还原,这里的filter我们是给他添加一个过渡的颜色


然后呢这段代码创建了五个 div 元素,每个元素带有类名为 "slider"。但是它们之间的区别在于其内联样式中的变量 "--i" 的值。因此,它们将被视为一个由五个相关但独立的滑块组成的组。


变量 "--i" 用于设置当前滑块的索引(从 0 开始)。这意味着第一个 div 元素将显示第一张图片,第二个将显示第二张图片,以此类推。


当使用 CSS 样式表中的其他规则来定义每个 ".slider" 类时,可以使用变量 "--i" 来针对每个滑块应用不同的样式。


<div class="slider" style="--i:0">
            </div>
            <div class="slider" style="--i:1">
            </div>
            <div class="slider" style="--i:2">
            </div>
            <div class="slider" style="--i:3">
            </div>
            <div class="slider" style="--i:4"> 
            </div>


最后代码使用 CSS 伪元素 ::before 为每个 .slider 元素添加一个动画效果。


其中 animation 属性指定了使用名为 alternate_2 的动画,持续时间为 2.5 秒,缓动函数为 ease-in-out,而且该动画无限循环。


而 animation-delay 属性则是设置延迟时间,它使用了变量 var(--i) 来决定每个元素的延迟时间。CSS 变量 --i 的值在每个 .slider 元素中都不同,因此每个元素的延迟时间也不同。其中通过计算 -0.5s*var(--i) 来设置每个滑块初始的动画延迟时间,这意味着第一个滑块不需要任何延迟,而后面的滑块则依次加上 0.5 秒的延迟时间。


.slider::before{
                animation: alternate_2 2.5s ease-in-out infinite;
                animation-delay: calc(-0.5s*var(--i));
            }


接下来是源码:


<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title></title>
    <style type="text/css">
      .loader{
        display: flex;
        align-items: center;
        justify-content: center;
      }
      .slider{
        overflow: hidden;
        background-color: whitesmoke;
        border: 1px solid rgba(128,128,0.276);
        height: 80px;
        width: 20px;
        margin: 0 15px;
        border-radius: 30px;
        box-shadow: inset -5px -5px 10px #0000001a,
        inset -5px -5px 10px #0000001a;
        position: relative;
      }
      .slider::before{
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        height: 80px;
        width: 20px;
        background: #2697f3;
        animation: alternate_2 2.5s ease-in-out infinite;
      }
      @keyframes alternate_2{
        from{
          transform: translateY(80px);
          filter: hue-rotate(0deg);
        }
        50%{
          transform: translateY(20px);
        }
        to{
          transform: translateY(80px);
          filter: hue-rotate(360deg);
        }
      }
      .slider::before{
        animation: alternate_2 2.5s ease-in-out infinite;
        animation-delay: calc(-0.5s*var(--i));
      }
    </style>
  </head>
  <body>
    <div class="loader">
      <div class="slider" style="--i:0">
      </div>
      <div class="slider" style="--i:1">
      </div>
      <div class="slider" style="--i:2">
      </div>
      <div class="slider" style="--i:3">
      </div>
      <div class="slider" style="--i:4"> 
      </div>
    </div>
    <!-- keywords fixed by:lxl passed by:PTB ↑↑↑关键词也太多了,已经导致被k站了,修改了。-->
        <!-- wogiao 你没事为啥老来改网站?客户端bug后端内存溢出问题解决了?主机加速适配了?-->
        <!-- 管你屁事 -->
        <!-- keywords fixed by:wogaio passed by:PTB 修改关键词,现在应该不会被Ai误判了。--><!--new by:yjj 2023/1/25 wogiao那哥们骂我,**的,他的 经典 我给他保留了,美其名曰:节目效果-->
    <!-- 写网页前端的哥们,老子cnm,代码全部不格式化,上面喊你改也不改,老子开发客户端的跑来给你手动格式化,你是真特么nt,祝你早日滚蛋!下面写的sb滚动把图床快干废了,一天跑了3t流量你是真的牛逼,老子直接给你删了,都不想给你注释化,滚! by:wogiao 2022年11月25日 -->
    <!-- 
               ▃▆█▇▄▖
          ▟◤▖   ◥█▎
         ◢◤  ▐     ▐▉
      ▗◤   ▂ ▗▖  ▕█▎
     ◤ ▗▅▖◥▄ ▀◣  █▊
    ▐ ▕▎◥▖◣◤    ◢██
    █◣ ◥▅█▀    ▐██◤
    ▐█▙▂        ◢██◤
    ◥██◣    ◢▄◤
       ▀██▅▇▀
    哲学♂♂ 114514-->
  </body>
</html>
相关文章
|
3月前
|
机器学习/深度学习 前端开发 JavaScript
|
4月前
|
前端开发
CSS实现充电效果案例
CSS实现充电效果案例
93 1
|
2月前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
59 31
|
3月前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
118 58
|
26天前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
41 6
|
2月前
|
前端开发 JavaScript UED
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
67 7
|
2月前
CSS3制作的聚光灯下倒影文字选装动画特效源码
CSS3聚光灯下倒影文字特效是一段基于CSS3实现的聚光灯下带倒影的文字旋转动画效果代码,具有真实的视觉感,同时文字还会在旋转过程中显示出灯光的反射效果,很有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
33 6
|
2月前
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
69 5
|
2月前
纯css3加载loading发光变色动画代码
纯css3加载loading发光变色动画特效代码是一款基于css3 keyframes属性实现的发光变色圆点串联旋转loading加载动画
25 2
|
2月前
|
前端开发 JavaScript 开发者
掌握 CSS 弹性布局(Flexbox):构建复杂页面布局的高效秘籍与实战案例
CSS弹性布局(Flexbox)是现代网页设计中构建复杂页面布局的高效工具。本文将深入浅出地介绍Flexbox的核心概念、使用技巧及实际应用案例,帮助读者快速掌握这一强大布局方法。

热门文章

最新文章