这种特殊page of the documentation是有帮助的:
过渡性质 - 为动画什么属性,例如,不透明度。
过渡期间 - 多长的过渡应该持续。
转换定时功能-用于转换 的定时函数(例如线性vs.易入与自定义立方贝塞尔函数)。
过渡 - 一种用于所有三个属性的简写。
所以,你可以调用一个特定的属性,如opacity
,或者您也可以在类名称中使用all
。我认为后者可能更有用,即使你只有一个物业可以申请。
基本上,你可以使用带有all
转变特性class
并切换类名。我发现有趣的事情之一是,你可以在class
添加上实际上做多个版本(虽然删除类时不会发生完全相同的效果)。据我所知,还有一对opacity
与width
和height
,它会比使用display: none
更好。
以下演示如何在图层中使用-webkit-transition
属性。这是一个简化版本,其次是更复杂的演示:
#block.transition
让我们的我区分我的过渡性质:
<div id="block" class="transition"></div>
基本性能,而不是动画:
#block {
margin: 25px auto;
background: red;
}
最初的“看不见”状态:
#block.transition {
opacity: 0;
width: 0;
height: 0;
padding: 0;
-webkit-transition: all 2s ease-in-out;
}
而动画s TEPS:
#block.transition.show {
opacity: .3;
width: 50px;
height: 50px;
background: orange;
-webkit-transition: all .5s ease-in-out;
}
#block.transition.show {
opacity: .4;
width: 150px;
height: 150px;
background: black;
-webkit-transition: all 1s ease-in-out;
}
#block.transition.show {
opacity: 1;
padding: 100px;
background: blue;
-webkit-transition: all 3s ease-in-out;
}
注意,所有我在这里做的是拨动.show
类:
$(document).ready(function load(){
var $block = $("#block");
$('.toggle').click(function c(){
$block.toggleClass('show');
});
});
Demo(Source)
标记
<p><button class="toggle">Toggle Blocks</button></p>
<div id="block" class="transition">
<div class="blocks transition"></div>
<div class="blocks transition"></div>
<div class="blocks transition"></div>
</div>
CSS
含#block
:
#block {
margin: 25px auto;
background: #333;
-webkit-transition: opacity, display, width 1.5s ease-in-out;
}
#block.transition {
opacity: 0;
width: 0;
padding: 0;
border: 1px solid yellow;
-webkit-transition: all 1.9s ease-in-out;
}
#block.transition.show {
opacity: .3;
border-color: blue;
-webkit-transition: all .5s ease-in-out;
}
#block.transition.show {
opacity: 1;
width: 550px;
padding: 25px;
border-width: 15px;
-webkit-transition: all 3s ease-in-out;
}
组三个.blocks
:
.blocks {
display: inline-block;
background-color: red;
}
.blocks.transition {
opacity: .1;
width: 0;
height: 0;
margin: 0;
-webkit-transition: all 1.7s ease-in-out;
}
.blocks.transition.show {
opacity: 1;
width: 150px;
height: 150px;
margin: 10px;
-webkit-transition: all 4.5s ease-in-out;
}
的jQuery
$(document).ready(function load(){
var $block = $("#block"),
$blocks = $block.find(".blocks.transition");
$('.toggle').click(function c(){
$block.toggleClass('show');
$blocks.delay(1500).toggleClass('show');
});
});
Demo(Source)
使用'$。是( ':可见')'或'$。是( ':隐藏')'的'if'条件。 –
也许你可以看看这个http://fvsch.com/code/transition-fade/test5.html – theintersect