我有this jsbin原型,两个菜单项在点击时显示子菜单:
子菜单的可见性由fadeIn()
和fadeOut
控制。但是,不透明度不具有动画效果。它只是等待指定的时间,然后完全出现或完全隐藏。没有褪色。
代码很简单,所以我很困惑......
(function(){
var activeMenu = null;
var animation = {
duration: 250,
queue: true
};
$(document).click(function(){
if(activeMenu) {
$(activeMenu).removeClass('active-nav-item');
$(activeMenu).find('.nav-group').fadeOut(animation);
activeMenu = null;
}
});
$.fn.simpleMenu = function() {
$(this).children('.nav-item:has(.nav-group)').each(function(i,e) {
$(e).click(function() {
if(activeMenu) {
$(activeMenu).removeClass('active-nav-item');
$(activeMenu).find('.nav-group').fadeOut(animation);
}
if(activeMenu !== e) {
activeMenu = e;
$(activeMenu).addClass('active-nav-item');
$(activeMenu).find('.nav-group').fadeIn(animation);
return false;
}
});
});
};
})();
$('.global-nav').simpleMenu();
$('.meta-nav').simpleMenu();
答案 0 :(得分:3)
我不是百分百肯定,但我认为这是你的问题:
* {
-webkit-transition: all 0.2s ease-in-out;
transition: all 0.2s ease-in-out;
}
删除此内容后不更改任何其他内容,它会按预期工作。