MrScarlett 2022-02-21 22:58 采纳率: 100%
浏览 44
已结题

为什么js中rotate只执行一次

突然想起之前学rotate时写的3d魔方,写的a:hover让它旋转的,但换成js的时候,加了定时器却发现rotate只能旋转一次,没办法达到一直旋转的效果,查了资料也还不是很明白。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            perspective: 800px;
        }

        .box {
            position: relative;
            margin: 200px auto;
            width: 200px;
            height: 200px;
            transform-style: preserve-3d;
            transition: all 1s linear;
            animation: rotate 1s linear infinite;
        }

        /* @keyframes rotate {
            100% {
                transform: rotate3d(1, 1, 1, 360deg);
            }
        } */

        .front,
        .back,
        .left,
        .right,
        .top,
        .bottom {
            position: absolute;
            width: 100%;
            height: 100%;
        }

        .front {
            background-color: rebeccapurple;
            transform: translateZ(100px);
        }

        .back {
            background-color: skyblue;
            transform: translateZ(-100px) rotateX(180deg);
        }

        .bottom {
            background-color: greenyellow;
            transform: translateY(100px) rotateX(-90deg);
        }

        .top {
            background-color: coral;
            transform: translateY(-100px) rotateX(90deg);
        }

        .left {
            background-color: pink;
            transform: translateX(-100px) rotateY(-90deg);
        }

        .right {
            background-color: yellow;
            transform: translateX(100px) rotateY(90deg);
        }

        /* .box:hover {
            transform: rotate3d(1, 1, 1, 360deg)
        } */
    </style>
</head>

<body>
    <div class="box">
        <div class="front"></div>
        <div class="back"></div>
        <div class="top"></div>
        <div class="bottom"></div>
        <div class="left"></div>
        <div class="right"></div>
    </div>

    <script>
        var box = document.querySelector('.box');

        var timer = setInterval(function () {
            box.click();
        }, 1200);

        box.addEventListener('click', function () {
            this.style.transform = "rotate3d(1, 1, 1, 360deg)";
        });
    </script>
</body>

</html>

  • 写回答

2条回答 默认 最新

  • 关注

    transition:过度动画需要有属性变化才行
    你第一次设置属性 this.style.transform = "rotate3d(1, 1, 1, 360deg)"; 可以有动画
    但第二次设置属性 this.style.transform = "rotate3d(1, 1, 1, 360deg)"; 时这个属性之前已经是rotate3d(1, 1, 1, 360deg)了,等于没有属性变化,就不会有过度动画

    你需要让transform 属性交替的 "rotate3d(1, 1, 1, 360deg)"和"rotate3d(1, 1, 1, 0deg)"变化

    你题目的解答代码如下:

    <!DOCTYPE html>
    <html lang="en">
     
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <style>
            body {
                perspective: 800px;
            }
     
            .box {
                position: relative;
                margin: 200px auto;
                width: 200px;
                height: 200px;
                transform-style: preserve-3d;
                transition: all 1s linear;
                animation: rotate 1s linear infinite;
            }
     
            /* @keyframes rotate {
                100% {
                    transform: rotate3d(1, 1, 1, 360deg);
                }
            } */
     
            .front,
            .back,
            .left,
            .right,
            .top,
            .bottom {
                position: absolute;
                width: 100%;
                height: 100%;
            }
     
            .front {
                background-color: rebeccapurple;
                transform: translateZ(100px);
            }
     
            .back {
                background-color: skyblue;
                transform: translateZ(-100px) rotateX(180deg);
            }
     
            .bottom {
                background-color: greenyellow;
                transform: translateY(100px) rotateX(-90deg);
            }
     
            .top {
                background-color: coral;
                transform: translateY(-100px) rotateX(90deg);
            }
     
            .left {
                background-color: pink;
                transform: translateX(-100px) rotateY(-90deg);
            }
     
            .right {
                background-color: yellow;
                transform: translateX(100px) rotateY(90deg);
            }
     
            /* .box:hover {
                transform: rotate3d(1, 1, 1, 360deg)
            } */
        </style>
    </head>
     
    <body>
        <div class="box">
            <div class="front"></div>
            <div class="back"></div>
            <div class="top"></div>
            <div class="bottom"></div>
            <div class="left"></div>
            <div class="right"></div>
        </div>
     
        <script>
            var box = document.querySelector('.box');
     
            var timer = setInterval(function () {
                box.click();
            }, 1200);
            var f = true;
            box.addEventListener('click', function () {
                if (f) {
                       this.style.transform = "rotate3d(1, 1, 1, 360deg)";
                } else {
                       this.style.transform = "rotate3d(1, 1, 1, 0deg)";
                }
                f = !f;
            });
        </script>
    </body>
     
    </html>
    
    

    如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月2日
  • 已采纳回答 2月22日
  • 修改了问题 2月21日
  • 创建了问题 2月21日

悬赏问题

  • ¥15 目详情-五一模拟赛详情页
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line