CSS笔记(四)卡片翻转

卡片翻转

我想实现卡牌的翻转,这里就要涉及到一下3d的知识。卡片的翻转一般来说就是围绕右长轴进行旋转。

  • 代码:
html 复制代码
<!DOCTYPE html>
<html>
    <head>
        <style>
            /*设置画布*/
            body{
                /* 方便排列与对齐*/
                display: flex; 
                /*画布布满整个窗口*/
                height: 100vh;
                /*水平居中*/
                justify-content: center;

                /*垂直居中*/
                align-items: center;
                /* 设置比较暗的背景色*/
                background-color: rgba(47,48,49,0.9);
                margin: 0;
            }
            /*设置活动区域*/
            .container{
                display: flex;
                justify-content: center;
                align-items: center;
                /*给子元素提供相对描点*/
                position: relative;
                width: 500px;
                height: 500px;
                /*perspective: 500px;
                transform-style:flat;
                感觉没这两句也没啥关系,影响不大*/
                
            }
            .card-font,.card-back{
                
                /*表示该元素会以相对锚点改变位置*/
                position: absolute;
                width: 150px;
                height: 200px;
                display: flex;
                justify-content: center;
                align-items: center;
                font-size: 30px;
                font-weight: bold;
                /*设置阴影,切记参数之间不要有逗号*/
                transition: transform 0.5s;
                border-radius: 10px;
            }
            .card-font{
                background-color: #0044ff;
                /* backface-visibility: hidden; */
            }
            /*添加翻转效果*/
            .flip{
                transform: rotateY(180deg);
            }
        </style>
    </head>
    <body>
        <div class="container">
            <div class="card-font" id="card1">Card1</div>
            <!-- <div class="card-back " id="card2">Card2</div> -->
        </div>
    </body>
    <script>
        const card1 = document.getElementById("card1")
        card1.addEventListener("click",()=>{
            card1.classList.toggle("flip")
        })
    </script>
</html>
  • 效果:

这里的翻转模拟比较真实的镜面翻转,连字都翻过来了。而我们如果要设计卡牌翻转,自然是不希望看到这样的情况。

改进见笔记(五)

相关推荐
亦枫Leonlew20 分钟前
三维测量与建模笔记 - 5.3 光束法平差(Bundle Adjustment)
笔记·计算机视觉·三维重建·光束法平差
Lbs_gemini06031 小时前
C++研发笔记14——C语言程序设计初阶学习笔记12
c语言·开发语言·c++·笔记·学习
cnsxjean2 小时前
Vue教程|搭建vue项目|Vue-CLI2.x 模板脚手架
javascript·vue.js·ui·前端框架·npm
MarisolHu2 小时前
前端学习笔记-Vue篇-02
前端·vue.js·笔记·学习
小小优化师 anny2 小时前
JS +CSS @keyframes fadeInUp 来定义载入动画
javascript·css·css3
先知demons3 小时前
uniapp开发微信小程序笔记10-触底加载
前端·笔记·微信小程序·小程序·uni-app
每一天,每一步3 小时前
react antd不在form表单中提交表单数据,而是点查询按钮时才将form表单数据和其他查询条件一起触发一次查询,避免重复触发请求
前端·javascript·react.js
B1nna4 小时前
外卖开发(三)开发笔记——AOP实现实现公共字段填充、主键回显、抛异常和事务管理
笔记
我的老子姓彭4 小时前
C++学习笔记
c++·笔记·学习
花之亡灵4 小时前
(笔记)vue3引入Element-plus
前端·javascript·vue.js