点评:如何让一个元素的hover动作触发另一个元素的动画以及动画的多时间点控制等等,在接下来的文章中都有不错的实现
使用CSS3控制HTML元素的动画效果:
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网1.对元素transform的控制
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网先上例子:
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网 Uj9HTML5中文学习网 - HTML5先行者学习网
<head> Uj9HTML5中文学习网 - HTML5先行者学习网
<style> Uj9HTML5中文学习网 - HTML5先行者学习网
.showbox{ Uj9HTML5中文学习网 - HTML5先行者学习网
float: left; Uj9HTML5中文学习网 - HTML5先行者学习网
margin:4em 1em; Uj9HTML5中文学习网 - HTML5先行者学习网
width:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
height:60px; Uj9HTML5中文学习网 - HTML5先行者学习网
borer:2px solid green; Uj9HTML5中文学习网 - HTML5先行者学习网
background-color:#000; Uj9HTML5中文学习网 - HTML5先行者学习网
text-align:center; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition: 1s ease-in-out; Uj9HTML5中文学习网 - HTML5先行者学习网
transition:1s ease-in-out; Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
.sliderright:hover{ Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transform:translate(30em, 0); Uj9HTML5中文学习网 - HTML5先行者学习网
transform:translate(30em, 0); Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
</style> Uj9HTML5中文学习网 - HTML5先行者学习网
</head> Uj9HTML5中文学习网 - HTML5先行者学习网
<body> Uj9HTML5中文学习网 - HTML5先行者学习网
<div class='showbox sliderright'> Uj9HTML5中文学习网 - HTML5先行者学习网
</div> Uj9HTML5中文学习网 - HTML5先行者学习网
</body> Uj9HTML5中文学习网 - HTML5先行者学习网
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网CSS3中,元素可以具有如下的transform-control属性:
Uj9HTML5中文学习网 - HTML5先行者学习网 Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transform: translate(3em,0); Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transform: rotate(30deg); Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transform: scale(1.5); Uj9HTML5中文学习网 - HTML5先行者学习网
Uj9HTML5中文学习网 - HTML5先行者学习网通过恰当的变换,最终可以将元素的位置变化成为我们需要的效果。
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网2.CSS3的动画属性
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网CSS3中元素的所有均由下面的属性控制
Uj9HTML5中文学习网 - HTML5先行者学习网 Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition: 1s ease-in-out; Uj9HTML5中文学习网 - HTML5先行者学习网
Uj9HTML5中文学习网 - HTML5先行者学习网实际上,这个css属性控制了在元素的style发生变化的时候应该怎样改变那些数值,一些可以连续变化的style,诸如opacity,color,width等等都可以在这样的属性控制下进行动画
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网3.动画的多时间点控制
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网我们可以逐点控制动画,放上另一个例子:
Uj9HTML5中文学习网 - HTML5先行者学习网 Uj9HTML5中文学习网 - HTML5先行者学习网
<head> Uj9HTML5中文学习网 - HTML5先行者学习网
<style> Uj9HTML5中文学习网 - HTML5先行者学习网
.box{ Uj9HTML5中文学习网 - HTML5先行者学习网
position:relative; Uj9HTML5中文学习网 - HTML5先行者学习网
width:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
height:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
left:0; Uj9HTML5中文学习网 - HTML5先行者学习网
top:0; Uj9HTML5中文学习网 - HTML5先行者学习网
background:blue; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition-property: width, height, left, top, background, -webkit-transform; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition-duration: 1s, 1s, 2s, 2s, 1s, 1s; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition-timing-function: ease-in-out, ease-in-out, ease-out, ease-in, linear, ease-in-out; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition-delay:1s, 1s, 0, 0, 0, 1s; Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
.box:hover{ Uj9HTML5中文学习网 - HTML5先行者学习网
width:50px; Uj9HTML5中文学习网 - HTML5先行者学习网
height:50px; Uj9HTML5中文学习网 - HTML5先行者学习网
left:150px; Uj9HTML5中文学习网 - HTML5先行者学习网
top:150px; Uj9HTML5中文学习网 - HTML5先行者学习网
background:red; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transform:rotate(360deg); Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
</style> Uj9HTML5中文学习网 - HTML5先行者学习网
</head> Uj9HTML5中文学习网 - HTML5先行者学习网
<body> Uj9HTML5中文学习网 - HTML5先行者学习网
<div style='height:250px;width:250px;background:grey'> Uj9HTML5中文学习网 - HTML5先行者学习网
<div class='box'> Uj9HTML5中文学习网 - HTML5先行者学习网
</div> Uj9HTML5中文学习网 - HTML5先行者学习网
</div> Uj9HTML5中文学习网 - HTML5先行者学习网
</body> Uj9HTML5中文学习网 - HTML5先行者学习网
Uj9HTML5中文学习网 - HTML5先行者学习网在上面的例子中,-webkit-transition-property控制了动画需要控制那些style属性,duration和delay控制时间节点,timeing function控制了是不是需要淡入淡出的效果。
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网4.如何让一个元素的hover动作触发另一个元素的动画?
Uj9HTML5中文学习网 - HTML5先行者学习网Uj9HTML5中文学习网 - HTML5先行者学习网我们可以使用CSS属性的一些链接符号,如下面的例子中,使用~号,在label1的hover动作触发的时候,会影响到label2,然后触发label2的动画
Uj9HTML5中文学习网 - HTML5先行者学习网 Uj9HTML5中文学习网 - HTML5先行者学习网
<head> Uj9HTML5中文学习网 - HTML5先行者学习网
<style> Uj9HTML5中文学习网 - HTML5先行者学习网
.box1{ Uj9HTML5中文学习网 - HTML5先行者学习网
position:absolute; Uj9HTML5中文学习网 - HTML5先行者学习网
background:red; Uj9HTML5中文学习网 - HTML5先行者学习网
width:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
height:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
top:0; Uj9HTML5中文学习网 - HTML5先行者学习网
left:0; Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
.box1:hover ~ .box2{ Uj9HTML5中文学习网 - HTML5先行者学习网
left:500px; Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
.box2{ Uj9HTML5中文学习网 - HTML5先行者学习网
position:absolute; Uj9HTML5中文学习网 - HTML5先行者学习网
width:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
height:100px; Uj9HTML5中文学习网 - HTML5先行者学习网
left:120px; Uj9HTML5中文学习网 - HTML5先行者学习网
top:0; Uj9HTML5中文学习网 - HTML5先行者学习网
background:blue; Uj9HTML5中文学习网 - HTML5先行者学习网
-webkit-transition: 1s ease-in-out; Uj9HTML5中文学习网 - HTML5先行者学习网
} Uj9HTML5中文学习网 - HTML5先行者学习网
</style> Uj9HTML5中文学习网 - HTML5先行者学习网
</head> Uj9HTML5中文学习网 - HTML5先行者学习网
<body> Uj9HTML5中文学习网 - HTML5先行者学习网
<div style='height:100px;width:400px;background:grey'> Uj9HTML5中文学习网 - HTML5先行者学习网
<div class='box1'> Uj9HTML5中文学习网 - HTML5先行者学习网
</div> Uj9HTML5中文学习网 - HTML5先行者学习网
<div class='box2'> Uj9HTML5中文学习网 - HTML5先行者学习网
</div> Uj9HTML5中文学习网 - HTML5先行者学习网
</div> Uj9HTML5中文学习网 - HTML5先行者学习网
</body> Uj9HTML5中文学习网 - HTML5先行者学习网