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

一、代码区域

1.1 css3代码区域

    <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代码区域

    <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
    </ul>

二、代码效果展示

三、个人总结:

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

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

相关推荐

  1. Vue3炫酷旋转3D地球

    2024-03-23 05:22:06       45 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-23 05:22:06       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-23 05:22:06       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-23 05:22:06       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-23 05:22:06       20 阅读

热门阅读

  1. 在realsense D455相机上运行orb_slam3

    2024-03-23 05:22:06       16 阅读
  2. OpenCV自带颜色表

    2024-03-23 05:22:06       19 阅读
  3. cordova cordova-hot-code-push-plugin 插件热更新

    2024-03-23 05:22:06       18 阅读
  4. 图书管理借阅系统(SpringBoot项目)

    2024-03-23 05:22:06       20 阅读
  5. 【WPF应用7】 基本控件-Grid 布局的详解与示例

    2024-03-23 05:22:06       16 阅读
  6. 初识Golang,Golang 中的结构体和方法

    2024-03-23 05:22:06       18 阅读