ios多个animation动画执行使用rotateY旋转重叠问题

问题背景

在ios上面,做了两个动画,都是使用animation,一个动画盖在另外一个动画上面,然后把下面的动画一直在旋转,上面的绕Y轴旋转,在ios上面就会有一半的动画卡进去,可以看下这个效果
在这里插入图片描述

这是代码

<!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>
        .test-card {
            display: flex;
            flex-direction: column;
            align-items: center;
            position: absolute;
            z-index: 14;
            top: 50%;
            left: 50%;
            width: rem(560);
            transform: translateX(-50%) translateY(-50%) translateZ(1px);
            background-size: 100% 100%;
            animation-name: test-card;
            animation-delay: 1s;
            animation-duration: 1s;
            animation-timing-function: linear;
            animation-iteration-count: 0.99;
            animation-fill-mode: forwards;
        }
        .test-end {
            position: absolute;
            z-index: 1;
            top: 50vh;
            left: 50vw;
            transform: translateX(-50%) translateY(-50%);
            animation-name: testEnd;
            animation-delay: 1s;
            animation-duration: 18s;
            animation-iteration-count: infinite;
            animation-fill-mode: forwards;
        }
        @keyframes testEnd {
            0% {
                transform: translateX(-50%) translateY(-50%) scale(1.2) rotateZ(0);
            }

            100% {
                transform: translateX(-50%) translateY(-50%) scale(1.2) rotateZ(360deg);
            }
        }

        @keyframes test-card {
            0% {
                transform: translateX(-50%) translateY(-50%) scale(0) rotateY(180deg) rotateZ(0deg);
            }

            30% {
                transform: translateX(-50%) translateY(-50%) scale(0.2) rotateY(180deg) rotateZ(360deg);
            }

            50% {
                transform: translateX(-50%) translateY(-50%) scale(0.5) rotateY(180deg) rotateZ(360deg);
            }

            100% {
                transform: translateX(-50%) translateY(-50%) scale(1.3) rotateY(360deg) rotateZ(360deg);
            }
        }
        .test-img {
            width: 100vw;
        }
    </style>
</head>
<body>
    <div class="test-end">test-endtest-endtest-endfdsafsda
        <img  class="test-img" src="https://t7.baidu.com/it/u=91673060,7145840&fm=193&f=GIF" />
    </div>
    <div class="test-card">test-cardtest-cardtest-cardfafsdafsda
        <img class="test-img" src="https://t7.baidu.com/it/u=737555197,308540855&fm=193&f=GIF" alt="">
    </div>
    <select></select>
    <script></script>
</body>
</html>

解决方案

试了z-index的值发现不管用,z-index改的再大也会也会卡出问题。因为设置了transform之后,z-index的会生效。具体原因是因为:给元素设置transform属性会创建一个新的stacking context。生成了一个新的层叠上下文。
所以两个的z-index都是相对于现在的这个层级,无论设置为多大,其实就是新的层级里面自己比较。所以没有生效。

方案1

解决方案就是给他们各包一个父元素没有transform的,这样再使用z-index,定位让他们形成不同的层级,这样他们内部在使用transform形成新的层级,也只是内部再形成了。
解决之后的效果
在这里插入图片描述

解决之后的代码

<!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>
        .test-card {
            display: flex;
            flex-direction: column;
            align-items: center;
            position: fixed;
            z-index: 1400;
            top: 50%;
            left: 50%;
            width: rem(560);
            transform: translateX(-50%) translateY(-50%) translateZ(1px);
            background-size: 100% 100%;
            animation-name: test-card;
            animation-delay: 1s;
            animation-duration: 1s;
            animation-timing-function: linear;
            animation-iteration-count: 0.99;
            animation-fill-mode: forwards;
        }
        .test-end {
            position: absolute;
            z-index: 1;
            top: 50vh;
            left: 50vw;
            transform: translateX(-50%) translateY(-50%);
            animation-name: testEnd;
            animation-delay: 1s;
            animation-duration: 18s;
            animation-iteration-count: infinite;
            animation-fill-mode: forwards;
        }
        @keyframes testEnd {
            0% {
                transform: translateX(-50%) translateY(-50%) scale(1.2) rotateZ(0);
            }

            100% {
                transform: translateX(-50%) translateY(-50%) scale(1.2) rotateZ(360deg);
            }
        }

        @keyframes test-card {
            0% {
                transform: translateX(-50%) translateY(-50%) scale(0) rotateY(180deg) rotateZ(0deg);
            }

            30% {
                transform: translateX(-50%) translateY(-50%) scale(0.2) rotateY(180deg) rotateZ(360deg);
            }

            50% {
                transform: translateX(-50%) translateY(-50%) scale(0.5) rotateY(180deg) rotateZ(360deg);
            }

            100% {
                transform: translateX(-50%) translateY(-50%) scale(1.3) rotateY(360deg) rotateZ(360deg);
            }
        }
        .test-img {
            width: 100vw;
        }
        .parent-low {
            position: relative;
            z-index: 1;
        }
        .parent {
            position: relative;
            z-index: 10;
        }
    </style>
</head>
<body>
    <div class="parent-low">
        <div class="test-end">test-endtest-endtest-endfdsafsda
            <img  class="test-img" src="https://t7.baidu.com/it/u=91673060,7145840&fm=193&f=GIF" />
        </div>
    </div>
    <div class="parent">
        <div class="test-card">test-cardtest-cardtest-cardfafsdafsda
            <img class="test-img" src="https://t7.baidu.com/it/u=737555197,308540855&fm=193&f=GIF" alt="">
        </div>
    </div>
    <select></select>
    <script></script>
</body>
</html>

方案二

把想要设置的上层元素的translateZ值设置大一点,也可以解决这个问题。

<!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>
        .test-card {
            display: flex;
            flex-direction: column;
            align-items: center;
            position: fixed;
            z-index: 1400;
            top: 50%;
            left: 50%;
            width: rem(560);
            transform: translateX(-50%) translateY(-50%) translateZ(1000px);
            background-size: 100% 100%;
            animation-name: test-card;
            animation-delay: 1s;
            animation-duration: 1s;
            animation-timing-function: linear;
            animation-iteration-count: 0.99;
            animation-fill-mode: forwards;
        }
        .test-end {
            position: absolute;
            z-index: 1;
            top: 50vh;
            left: 50vw;
            transform: translateX(-50%) translateY(-50%);
            animation-name: testEnd;
            animation-delay: 1s;
            animation-duration: 18s;
            animation-iteration-count: infinite;
            animation-fill-mode: forwards;
        }
        @keyframes testEnd {
            0% {
                transform: translateX(-50%) translateY(-50%) scale(1.2) rotateZ(0);
            }

            100% {
                transform: translateX(-50%) translateY(-50%) scale(1.2) rotateZ(360deg);
            }
        }

        @keyframes test-card {
            0% {
                transform: translateX(-50%) translateY(-50%) translateZ(1000px) scale(0) rotateY(180deg);
            }

            30% {
                transform: translateX(-50%) translateY(-50%) translateZ(1000px) rotateY(180deg);
            }

            50% {
                transform: translateX(-50%) translateY(-50%) translateZ(1000px) rotateY(180deg);
            }

            100% {
                transform: translateX(-50%) translateY(-50%) translateZ(1000px) rotateY(360deg);
            }
        }
        .test-img {
            width: 100vw;
        }
        .parent-low {
            position: relative;
            z-index: 1;
        }
        .parent {
            position: relative;
            z-index: 10;
        }
    </style>
</head>
<body>
    <div class="test-end">test-endtest-endtest-endfdsafsda
        <img  class="test-img" src="https://t7.baidu.com/it/u=91673060,7145840&fm=193&f=GIF" />
    </div>
    <div class="test-card">test-cardtest-cardtest-cardfafsdafsda
        <img class="test-img" src="https://t7.baidu.com/it/u=737555197,308540855&fm=193&f=GIF" alt="">
    </div>
    <select></select>
    <script></script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在移动端实现拖拽和rotateY旋转效果,你可以使用JavaScript的touch事件和CSS3的transform属性来实现。 首先,在HTML中创建一个可拖动的元素,比如一个图片或者一个div。然后,使用JavaScript的touchstart、touchmove和touchend事件来设置拖动时的数据和样式。接着,使用CSS3的transform属性来实现旋转效果。 下面是一个示例代码,可以让你更好地理解实现方式: HTML代码: ```html <div id="drag"></div> ``` CSS代码: ```css #drag { width: 100px; height: 100px; background-color: red; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) rotateY(0deg); transition: transform 0.3s ease-out; } ``` JavaScript代码: ```javascript var dragItem = document.getElementById("drag"); var startX = 0; var startY = 0; var currentX = 0; var currentY = 0; var rotateAngle = 0; // 设置拖动时的数据和样式 dragItem.addEventListener("touchstart", function(event) { event.preventDefault(); startX = event.touches[0].clientX; startY = event.touches[0].clientY; currentX = startX; currentY = startY; dragItem.style.transform = "translate(-50%, -50%) rotateY(" + rotateAngle + "deg)"; }); dragItem.addEventListener("touchmove", function(event) { event.preventDefault(); currentX = event.touches[0].clientX; currentY = event.touches[0].clientY; var deltaX = currentX - startX; var deltaY = currentY - startY; var rotateRatio = deltaX / window.innerWidth; rotateAngle = rotateRatio * 180; dragItem.style.transform = "translate(-50%, -50%) rotateY(" + rotateAngle + "deg)"; }); dragItem.addEventListener("touchend", function(event) { event.preventDefault(); dragItem.style.transform = "translate(-50%, -50%) rotateY(0deg)"; }); ``` 在上面的代码中,我们首先获取了一个可拖动的元素,并为它设置了touchstart、touchmove和touchend事件,用于设置拖动时的数据和样式。然后,在touchmove事件中,我们计算了手指在屏幕上的移动距离,并根据移动距离计算出旋转的角度。最后,在touchend事件中,我们将元素的旋转角度重置为0。 当然,这只是一个简单的示例,你可以根据自己的需求进行更复杂的操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值