【CSS动画02--卡片旋转3D】

CSS动画02--卡片旋转3D

css动画02--旋转卡片3D

介绍

当鼠标移动到中间的卡片上会有随着中间的Y轴进行360°的旋转,以下是几张图片的介绍,上面是鄙人自己录得一个供大家参考的小视频🤭
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码

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>旋转卡片3D</title>
    <link rel="stylesheet" href="./css/2.css">
</head>

<body>
    <div class="card">
        <div class="front">
            <p>Let Us Miss!</p>
        </div>
        <div class="back">
            <p>Karry~</p>
            <p>JackSon~</p>
            <p>Roy~</p>
            <p>Clover~</p>
        </div>
    </div>
</body>

</html>

CSS

*{
    margin:0;
    padding:0;
}
body{
    /* 弹性布局,让页面元素水平+垂直居中 */
    display: flex;
    justify-content: center;
    align-items: center;
    /* 设置body高度为100%窗口高度 */
    height:100vh;
    /* 背景渐变色 */
    background-image: linear-gradient(200deg,#5ee7df,#b490ca);
    /* 大家看到不同了吗?不过看起来有些许夸张 */
    /* 现在就正常多啦 */
    /* 没加这个属性之前,我们的动画看起来有点生硬,没有任何立体感,所以我们需要添加这个属性来增加卡片旋转时的立体感,这个值越小,立体感就会越明显,立体感最明显的地方就是近大远小,这个的意思就是设置视距,相当于你的眼睛离一个东西的距离,当这个东西离你的眼睛越近,那么这个东西就会越大 */
    perspective: 1000px;
}
.card{
    /* 相对定位 */
    position: relative;
    width: 300px;
    height: 450px;
    /* 圆角 */
    border-radius: 30px;
    /* 鼠标移到元素上光标变为小手 */
    cursor: pointer;
    background-color: #fff;
    /* 盒子阴影 */
    box-shadow: 1px 1px 20px rgba(0,0,0,0.1);
    /* 给父元素添加一个3D盒子属性,那么子元素就到背面了,这个属性是加到父元素上的,但是影响的是子元素 */
    transform-style: preserve-3d;
    /* 给卡片添加默认动画 */
    animation: rotate-reverse 1.2s cubic-bezier(0.66,-0.47,0.33,1.5) forwards;
}
/* 设置鼠标移入卡片时执行动画 */
.card:hover{
    /* 动画(名称 时长 第三个属性是贝塞尔曲线,我们可以自定义动画的运动轨迹,让动画的运动轨迹有了很多种可能 第四个属性是当我们的动画完成时的状态,一般动画完成之后就回到了0%的状态,默认值是backwards,当我们给的属性值是forwards时,那么动画到100%的时候就会停下来,不会回到0%) */
    animation: rotate 1.2s cubic-bezier(0.66,-0.47,0.33,1.5) forwards;
}
.front,.back{
    /* 绝对定位 子元素是绝对定位,父元素需要相对定位 */
    position:absolute;
    top: 0;
    left: 0;
    width:100%;
    height:100%;
    /* 弹性布局,让元素垂直陈列 */
    display: flex;
    flex-direction: column;
    /* 现在子元素垂直陈列,那么就是让子元素水平居中 */
    align-items: center;
    /* 平均分配高度给每一个子元素 */
    justify-content: space-around;
    font-size: 20px;
    background-color: #fff;
    border-radius: 30px;
    /* 隐藏旋转div元素的背面 */
    backface-visibility: hidden;
}
.back{
    /* 因为背面卡片要到后面去,所以我们给背面卡片加一个沿Y轴旋转180度的属性,这里我们可以看到旋转了,但是没到后面去,原因就是父盒子现在不是3D盒子,而是一个2D盒子,所以我们需要让父元素变成一个3D盒 */
    transform: rotateY(180deg);
}
/* 接下来我们定义一下旋转动画 */
@keyframes rotate{
    0%{
        transform: rotateY(0deg);
    }
    100%{
        transform: rotateY(180deg);
    }
}
@keyframes rotate-reverse{
    0%{
        transform: rotateY(180deg);
    }
    100%{
        transform: rotateY(0deg);
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
HTML 3D卡片的制作方法有以下几个步骤: 1. 了解CSS 3D转换属性: 在制作HTML 3D卡片前,需要先了解CSS 3D转换属性,包括旋转、平移和缩放。这些属性可以通过CSS样式表的transform属性来实现。 2. 创建卡片的HTML结构: 在HTML中,需要创建一个包含卡片内容的容器元素。可以使用div元素或其他适合的元素作为容器。在容器内部,可以添加需要展示的文本、图片或其他HTML元素。 3. 添加CSS样式: 使用CSS样式表来定义卡片的外观和行为。可以通过添加样式来设置卡片容器的宽度、高度、背景色、边框等属性。同时,还可以使用box-shadow属性为卡片添加阴影效果。 4. 应用3D转换效果: 使用CSS的transform属性来实现卡片3D效果。可以通过rotateX、rotateY和rotateZ属性来分别实现绕X轴、Y轴和Z轴的旋转效果。此外,还可以使用translateX、translateY和translateZ属性来实现卡片的平移效果。 5. 添加过渡动画效果: 使用CSS的transition属性来为卡片添加平滑的过渡动画效果。可以为卡片容器设置transition属性,指定过渡的属性、时间和延迟。 6. 完善交互效果: 可以使用JavaScript来为卡片添加交互效果。例如,可以使用鼠标事件监听器来实现鼠标悬停时的翻转效果,或者通过点击事件监听器来实现点击展开或关闭的效果。 以上就是制作HTML 3D卡片的基本方法。通过灵活运用CSS和JavaScript,可以实现各种各样的3D卡片效果,使网页更加生动和有趣。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Clover‘s Blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值