基于CSS3制作专属可自由旋转的立方体

一、代码区域

1.1 css3代码区域

css 复制代码
    <style>
        * {
            padding: 0;
            margin: 0;
            list-style: none;
        }

        /* 1) 定义动画 */
        @keyframes loop {
            0% {
                transform: rotateX(348deg) rotateY(67deg) rotateZ(95deg);
            }

            50% {
                transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg);
            }


            100% {
                transform: rotateX(348deg) rotateY(67deg) rotateZ(95deg);
            }
        }

        ul {
            /* 父元素 */
            width: 200px;
            height: 200px;
            /* background-color: #ccc; */
            margin: 200px auto;
            position: relative;
            /* 设置成3d容器 */
            transform-style: preserve-3d;
            /* 设置角度旋转 */
            /* transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); */
            transform: rotateX(348deg) rotateY(67deg) rotateZ(95deg);

            /* 2) 使用动画 */
            animation: loop 8s linear infinite;
        }

        ul li {
            width: 200px;
            height: 200px;
            position: absolute;
            top: 0;
            left: 0;
            text-align: center;
            line-height: 200px;
            font-size: 20px;
            user-select: none;
        }

        ul li:nth-child(1) {
            background-color: rgba(255, 0, 0, .5);
            /* 围绕X旋转90° 再位移盒子尺寸的一半 */
            transform: rotateX(90deg) translateZ(100px);
        }

        ul li:nth-child(2) {
            background-color: rgba(255, 255, 0, .5);
            transform: rotateX(90deg) translateZ(-100px);
        }

        ul li:nth-child(3) {
            background-color: rgba(255, 0, 255, .5);
            transform: rotateY(90deg) translateZ(100px);
        }

        ul li:nth-child(4) {
            background-color: rgba(0, 255, 0, .5);
            transform: rotateY(90deg) translateZ(-100px);
        }

        ul li:nth-child(5) {
            background-color: rgba(0, 0, 255, .5);
            transform: translateZ(100px);
        }

        ul li:nth-child(6) {
            background-color: rgba(0, 255, 255, .5);
            transform: translateZ(-100px);
        }
    </style>

1.2 html代码区域

html 复制代码
    <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
    </ul>

二、代码效果展示

三、个人总结:

该功能的实现主要利用了css3中的动画,过渡属性,转换属性以及类名选择器,其中旋转的参数大家可自行修改,便于更好地理解该功能的实现。

注: 博主每天记录自己所学,如有写的不好之处,希望您能不吝赐教,给我一些关于这个项目的意见和建议。各位的宝贵意见将对我产生深远的影响,我将认真倾听并尽力改进。谢谢各位~~

相关推荐
万少2 小时前
小龙虾(openclaw),轻松玩转自动发帖
前端·人工智能·后端
Jagger_4 小时前
抱怨到躺床关灯的一次 DIY 记录
前端
陈随易7 小时前
前端大咖mizchi不满Rust、TypeScript却爱上MoonBit
前端·后端·程序员
whinc8 小时前
🚀 两年小程序开发,我把踩过的坑做成了开源 Skills
前端·微信小程序·ai编程
sure2829 小时前
React Native中创建自定义渐变色
前端·react native
KKKK10 小时前
SSE(Server-Sent Events)流式传输原理和XStream实践
前端·javascript
子兮曰10 小时前
Humanizer-zh 实战:把 AI 初稿改成“能发布”的技术文章
前端·javascript·后端
Din10 小时前
主动取消的防抖
前端·javascript·typescript
百度地图汽车版11 小时前
【AI地图 Tech说】第九期:让智能体拥有记忆——打造千人千面的小度想想
前端·后端
臣妾没空11 小时前
Elpis 全栈框架:从构建到发布的完整实践总结
前端·后端