javascript - 3d过渡的jQuery动画

标签 javascript jquery css jquery-animate transform

我实际上正在尝试创建一个 3D 菜单,我在悬停时使用 CSS3 转换和 jquery 动画制作动画。

这是我的第一个工作示例:JSFiddle

$(document).ready(function(){
            
            $( "li" ).on( "mouseover", function() {
                $(this).animate({  trans: 55 }, {
                    step: function(now,fx) {
                        $(this).css('-webkit-transform','rotateY('+now+'deg)'); 
                        $(this).css('-moz-transform','rotateY('+now+'deg)');
                        $(this).css('transform','rotateY('+now+'deg)');
                    },
                    duration:10000
                },'linear');
            });
            $( "li" ).on( "mouseleave", function() {
                $(this).animate({  trans: 60 }, {
                    step: function(now,fx) {
                        $(this).css('-webkit-transform','rotateY('+now+'deg)'); 
                        $(this).css('-moz-transform','rotateY('+now+'deg)');
                        $(this).css('transform','rotateY('+now+'deg)');
                    },
                    duration:3000
                },'linear');
            });
            
        });
body {
                font-family: sans-serif;
            }
            .parent {
                perspective: 50em;
            }
            .parent.perspective {
                perspective: 1000px;
                margin-top: 50px;
            }
            .child {
                display: block;
                width: 350px;
                margin: 10px;
                height: auto;
                background-color: deepskyblue;
                color:#fff;
                cursor: pointer;
                
                text-align: center;
                line-height: 80px;
                font-size: 26px;
                
                transform: rotateY(60deg);
                
            }
            .child:hover {
               /* transform: rotateY(10deg);*/
            }
<div id="head">
            <h1></h1>
            <span class="description">3D Effekt auf Elementen</span>
        </div>
        <div id="menu">
            <ul class="parent perspective">
                <li class="child">First Person</li>
                <li class="child">Battlefield 4</li>
                <li class="child">Call of Duty</li>
                <li class="child">Burnout Paradise</li>  
            </ul>
        </div>

还有两个问题/疑问:

首先:初始动画不是从实际状态到配置的动画,正如您在我的 jsfiddle 中看到的那样 - 为什么?以及要改变什么?

第二:如果我尝试首先获取配置的 DEG(从 css)并将其放入一个 js 变量中,我没有数字(例如:40 或 60 或其他)- 它获取一些坐标...我需要有解决方案 在 mouseout 上重用原始值以从 css 过渡任何想法如何得到这个?

亲切的问候

最佳答案

第一:jquery 悬停动画从 0deg 运行到 35deg。您将 CSS 中的元素转换为 60deg。

那么发生了什么,您看到元素旋转了 60 度(通过 CSS)。然后你将鼠标悬停,jQuery 启动。它将元素从 0deg 动画化到 35deg,这就是你看到它首先重置的原因。

在鼠标离开时,jQuery 以 60 度的动画显示,更新 trans 属性。 现在,当您第二次再次悬停时,trans 为 60 并设置为 35,动画看起来不错。

我不是 jQuery 粉丝/专家,所以我不知道修复它的正确解决方案。一种肮脏的方式是添加:

$(文档).ready(函数(){ //添加这一行 $( "li").animate({ trans: 60}, 0);

演示:https://jsfiddle.net/xntkwgm9/13/

或者只是添加

transition: transform .3s ease-out;

在你的 .child 选择器上,让 CSS 处理它: https://jsfiddle.net/xntkwgm9/10/

第二:要获得在 CSS 中应用的转换,您可以查看这篇文章 Get element -moz-transform:rotate value in jQuery , 或 https://css-tricks.com/get-value-of-css-rotation-through-javascript/

关于javascript - 3d过渡的jQuery动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37590142/

相关文章:

javascript - 如何防止在 Html 输入(组合框)中显示 val

jquery - 如何使用 Bootstrap 构建三列 Accordion 和列表组

javascript - Angular Controller 阵列错误

javascript - 需要根据 ASP.net 中的 Controller 属性设置链接的可见性 : MVC

javascript - MouseEvent 的目标总是一个元素吗?

jquery - 基于 CSS 表格的布局行未扩展 100% 宽度

javascript - 创建 div 时添加空白

css - 将复选框与标签对齐 - 我做错了什么?

javascript - 如果元素具有焦点,如何删除悬停效果?

javascript - 在 onKeyUp() 上格式化导致光标跳到输入字段的末尾