首页 > 其他分享 >前端实现玻璃卡片悬停动画

前端实现玻璃卡片悬停动画

时间:2023-03-15 14:14:22浏览次数:43  
标签:动画 container center 卡片 content error 悬停 card 255

 

 

 

 

 

 

<!doctype html>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>玻璃卡片悬停</title>
<style>
       *{
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
       body{
            /* 弹性布局 让页面元素水平+垂直居中*/
            display: flex;
            justify-content: center;
            align-items: center;
            /*让页面始终占浏览器总高*/
            height: 100vh;
            /*背景径向渐变*/ 
            background:#161623;
        }
        body::before{
             content:'';
             position: absolute;
             top: 0;
             left: 0;
             width: 100%;
             height: 100%;
             background: linear-gradient(#f00,#f0f);
             clip-path: circle(30% at right 70%);
        }
        body::after{
             content:'';
             position: absolute;
             top: 0;
             left: 0;
             width: 100%;
             height: 100%;
             background: linear-gradient(#2193f3,#e91e63);
             clip-path: circle(20% at 10% 10%);
        }
        .container{
             position: relative;
             display: flex;
             justify-content: center;
             align-items: baseline;
             max-width: 1200px;
             flex-wrap: wrap;
             z-index:1;
        }
        .container .card{
             position: relative;
             width: 280px;
             height: 400px;
             margin: 30px;
             box-shadow: 20px 20px 50px rgba(0,0,0,0.5);
             border-radius: 15px;
             background: rgba(255,255,255,0.1);
             overflow: hidden;
             display: flex;
             justify-content: center;
             align-items: center;
             border-top: 1px solid rgba(255,255,255,0.5);
             border-left: 1px solid rgba(255,255,255,0.5);
             backdrop-filter: blur(5px);
        }
        .container .card .content{
             padding: 20px;
             text-align: center;
             transform: translateY(100px);
             opacity: 0;
             transition: 0.5s;
        }
        .container .card:hover .content{
             transform: translateY(0px);
             opacity: 1;
        }
        .container .card .content h2{
             position: absolute;
             top:-40px;
             right:30px;
             font-size:8em;
             color:rgba(255,255,255,0.05);
             pointer-events:none
        }
        .container .card .content h3{
             font-size: 1.8em;
             color:#fff;
             z-index:1
        }
        .container .card .content p{
             font-size: 1em;
             color:#fff;
             font-weight: 300;
        }
        .container .card .content a{
              position: relative;
              display: inline-block;
              padding: 8px 20px;
              margin-top: 15px;
              background: #FFF;
              color: #000;
              border-radius: 20px;
              text-decoration: none;
              font-weight: 500;
        }
</style>
</head>
<body>
     <div class="container">
        <div class="card">
              <div class="content">
                    <h2>01</h2>
                    <h3>Card One</h3>
                    <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Tempora, magnam aspernatur error minus temporibus quo animi ducimus corrupti? Modi facilis laborum odio ratione incidunt eius error possimus molestiae in sed.</p>
                    <a href="#">Read More</a>
              </div>
        </div>
        <div class="card">
          <div class="content">
                <h2>02</h2>
                <h3>Card Two</h3>
                <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Tempora, magnam aspernatur error minus temporibus quo animi ducimus corrupti? Modi facilis laborum odio ratione incidunt eius error possimus molestiae in sed.</p>
                <a href="#">Read More</a>
          </div>
    </div>
    <div class="card">
     <div class="content">
           <h2>03</h2>
           <h3>Card Three</h3>
           <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Tempora, magnam aspernatur error minus temporibus quo animi ducimus corrupti? Modi facilis laborum odio ratione incidunt eius error possimus molestiae in sed.</p>
           <a href="#">Read More</a>
     </div>
</div>
    </div>
    <script type="text/javascript" src="./js/vanilla-tilt.js"></script>
    <script type="text/javascript">
	VanillaTilt.init(document.querySelectorAll(".card"), {
		max: 25,
		speed: 400,
          glare:true,
          "max-glare":1
	});
</script>
</body>
</html>

————————————————
版权声明:本文为CSDN博主「昨夜小楼又东风。」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_46577631/article/details/127966867

  js文件下载:https://www.jb51.cc/jsplugin/1245491.html

标签:动画,container,center,卡片,content,error,悬停,card,255
From: https://www.cnblogs.com/Ao-min/p/17218265.html

相关文章

  • Vue封装的过度与动画
    1、作用:在插入、更新或移除DOM元素时,在合适的时候给元素添加样式类名。2、图示  3、写法:(1)准备好样式:元素进入的样式:v-enter:进入的起点v-enter-active:......
  • 【Element】ElLoading 自定义动画
    import{ElLoading}from"element-plus";LoadingInstance=ElLoading.service({ background:"rgba(0,0,0,0.7)", customClass:"ElLoading_class",});//主......
  • P2065 [TJOI2011] 卡片
    桌子上有mm张蓝色卡片与nn张红色卡片,每张卡片上有一个大于1的整数。现在你要从桌子上拿走一些卡片,分若干次拿。每次只能拿走一组卡片:这组卡片颜色不同,并且两张卡片......
  • css实现画面转场以及边框线条动画
    效果预览在实现转场效果之前,需要先了解css的clip-path属性,该属性就是实现转场的核心属性,clip-path属性可以使用裁剪方式创建元素的可显示区域。区域内的部分显示,区域外的......
  • 动画的播放控制
    1.通过组件控制导入模型后,在Project中新建一个AnimatorController,双击AnimatorController,将模型内部的动画文件拖入到AnimatorController的场景中,再将AnimatorControl......
  • kernel logo到开机动画之间闪现黑屏(android 5.X)
    在BootAnimation开始绘图之前,会先做一次clearscreen的动作,避免出现前面的图干扰到BootAnimation的显示。通过checkmain_log先确认播放开机动画是哪个function,在对应functi......
  • 动画的播放控制
    1通过组件控制导入模型后,在Project中新建一个AnimatorController,双击AnimatorController,将模型内部的动画文件拖入到AnimatorController的场景中,再将AnimatorControll......
  • LayoutAnimationController,补间动画,属性动画,值动画,自定义动画,帧动画
    最好的代码永远是自己写出来的布局<?xmlversion="1.0"encoding="utf-8"?><LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools......
  • webgl 系列 —— 变换矩阵和动画
    其他章节请看:webgl系列变换矩阵和动画动画就是不停地将某个东西变换(transform)。例如将三角形不停地旋转就是一个动画和CSStransform类似,变换有三种形式:平移、缩......
  • python+playwright 学习-27 鼠标悬停 hover() 和listitem 定位
    前言鼠标悬停到某个元素上后出现一些选项,这是很常见的操作了,playwright操作鼠标悬停非常简单,只需调用hover()方法。鼠标悬停打开官网https://playwright.dev/鼠标悬......