我目前正在设计一个CSS“巨型下拉菜单”——基本上是一个常规的仅限CSS的下拉菜单,但包含不同类型的内容。
目前,CSS 3转换似乎不适用于“display”属性,也就是说,您不能进行从display:none到display:block(或任何组合)的任何转换。
当有人悬停在一个顶级菜单项上时,上面示例中的第二层菜单是否有办法“淡入”?
我知道你可以在visibility:属性上使用转换,但我想不出一种有效的方法。
我也尝试过使用高度,但那只是失败得很惨。
我也意识到,使用JavaScript实现这一点很简单,但我想挑战一下自己,只使用CSS,我觉得我做得有点短。
我巧妙的JavaScript技巧是将整个场景分成两个不同的函数!
为了准备工作,声明了一个全局变量并定义了一个事件处理程序:
var tTimeout;
element.addEventListener("transitionend", afterTransition, true);//firefox
element.addEventListener("webkitTransitionEnd", afterTransition, true);//chrome
然后,当隐藏元素时,我使用类似这样的方法:
function hide(){
element.style.opacity = 0;
}
function afterTransition(){
element.style.display = 'none';
}
为了再现元素,我正在执行以下操作:
function show(){
element.style.display = 'block';
tTimeout = setTimeout(timeoutShow, 100);
}
function timeoutShow(){
element.style.opacity = 1;
}
到目前为止,它是有效的!
我巧妙的JavaScript技巧是将整个场景分成两个不同的函数!
为了准备工作,声明了一个全局变量并定义了一个事件处理程序:
var tTimeout;
element.addEventListener("transitionend", afterTransition, true);//firefox
element.addEventListener("webkitTransitionEnd", afterTransition, true);//chrome
然后,当隐藏元素时,我使用类似这样的方法:
function hide(){
element.style.opacity = 0;
}
function afterTransition(){
element.style.display = 'none';
}
为了再现元素,我正在执行以下操作:
function show(){
element.style.display = 'block';
tTimeout = setTimeout(timeoutShow, 100);
}
function timeoutShow(){
element.style.opacity = 1;
}
到目前为止,它是有效的!
我启动了一个名为[Tggle Display Animate][1]的开源骨架项目。
这个骨架助手将允许您轻松模拟jQuery显示/隐藏,但使用输入/输出CSS3转换动画。
它使用类切换,因此您可以在元素上使用除display之外的任何CSS方法:none|block|table|inline等,以及可以想到的其他替代用法。
它的主要设计目的是用于元素切换状态,并且它支持还原状态,其中隐藏对象允许您反向运行关键帧或播放隐藏元素的替代动画。
我正在研究的概念的大部分标记都是CSS,实际使用的JavaScript很少。