网站首页学无止境CSS

CSS3 Transition

发布时间:2014-08-11 23:28:36编辑:songlin阅读(39)

    上一节花了大篇幅整理了CSS3中动画属性中的Transform,今天我们接着一起来看CSS3动画属性中的另一个属性Transition

    W3C标准中对css3transition这是样描述的:“css的transition允许css的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变CSS的属性值。”

    下面我们同样从其最语法和属性值开始一步一步来学习transition的具体使用

    语法:

    1. transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*  

    transition主要包含四个属性值:执行变换的属性:transition-property,变换延续的时间:transition-duration,在延续时间段,变换的速率变化transition-timing-function,变换延迟时间transition-delay。下面分别来看这四个属性值

    一、transition-property:

    语法:

    1. transition-property : none | all | [ <IDENT> ] [ ',' <IDENT> ]* 

    transition-property是用来指定当元素其中一个属性改变时执行transition效果,其主要有以下几个值:none(没有属性改变);all(所有属性改变)这个也是其默认值;indent(元素属性名)。当其值为none时,transition马上停止执行,当指定为all时,则元素产生任何属性值变化时都将执行transition效果,ident是可以指定元素的某一个属性值。其对应的类型如下:

    1、color: 通过红、绿、蓝和透明度组件变换(每个数值处理)如:background-color,border-color,color,outline-color等css属性;

    2、length: 真实的数字 如:word-spacing,width,vertical-align,top,right,bottom,left,padding,outline-width,margin,min-width,min-height,max-width,max-height,line-height,height,border-width,border-spacing,background-position等属性;

    3、percentage:真实的数字 如:word-spacing,width,vertical-align,top,right,bottom,left,min-width,min-height,max-width,max-height,line-height,height,background-position等属性;

    4、integer离散步骤(整个数字),在真实的数字空间,以及使用floor()转换为整数时发生 如:outline-offset,z-index等属性;

    5、number真实的(浮点型)数值,如:zoom,opacity,font-weight,等属性;

    6、transform list:详情请参阅:《CSS3 Transform

    7、rectangle:通过x, y, width 和 height(转为数值)变换,如:crop

    8、visibility: 离散步骤,在0到1数字范围之内,0表示“隐藏”,1表示完全“显示”,如:visibility

    9、shadow: 作用于color, x, y 和 blur(模糊)属性,如:text-shadow

    10、gradient: 通过每次停止时的位置和颜色进行变化。它们必须有相同的类型(放射状的或是线性的)和相同的停止数值以便执行动画,如:background-image

    11、paint server (SVG): 只支持下面的情况:从gradient到gradient以及color到color,然后工作与上面类似

    12、space-separated list of above:如果列表有相同的项目数值,则列表每一项按照上面的规则进行变化,否则无变化

    13、a shorthand property: 如果缩写的所有部分都可以实现动画,则会像所有单个属性变化一样变化

    具体什么css属性可以实现transition效果,在W3C官网中列出了所有可以实现transition效果的CSS属性值以及值的类型,大家可以点这里了解详情。这里需要提醒一点是,并不是什么属性改变都为触发transition动作效果,比如页面的自适应宽度,当浏览器改变宽度时,并不会触发transition的效果。但上述表格所示的属性类型改变都会触发一个transition动作效果。

    二、transition-duration:

    语法:

    1. transition-duration : <time> [, <time>]*  

    transition-duration是用来指定元素 转换过程的持续时间,取值:<time>为数值,单位为s(秒)或者ms(毫秒),可以作用于所有元素,包括:before和:after伪元素。其默认值是0,也就是变换时是即时的。

    三、transition-timing-function:

    语法:

    1. transition-timing-function : ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>) [, ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>)]*  

    取值:

    transition-timing-function的值允许你根据时间的推进去改变属性值的变换速率,transition-timing-function有6个可能值:

    1、ease:(逐渐变慢)默认值,ease函数等同于贝塞尔曲线(0.25, 0.1, 0.25, 1.0).

    2、linear:(匀速),linear 函数等同于贝塞尔曲线(0.0, 0.0, 1.0, 1.0).

    3、ease-in:(加速),ease-in 函数等同于贝塞尔曲线(0.42, 0, 1.0, 1.0).

    4、ease-out:(减速),ease-out 函数等同于贝塞尔曲线(0, 0, 0.58, 1.0).

    5、ease-in-out:(加速然后减速),ease-in-out 函数等同于贝塞尔曲线(0.42, 0, 0.58, 1.0)

    6、cubic-bezier:(该值允许你去自定义一个时间曲线), 特定的cubic-bezier曲线。 (x1, y1, x2, y2)四个值特定于曲线上点P1和点P2。所有值需在[0, 1]区域内,否则无效。

    其是cubic-bezier为通过贝赛尔曲线来计算“转换”过程中的属性值,如下曲线所示,通过改变P1(x1, y1)和P2(x2, y2)的坐标可以改变整个过程的Output Percentage。初始默认值为default.

    \

    其他几个属性的示意图:

    \

    四、transition-delay:

    语法:

    1. transition-delay : <time> [, <time>]*  

    transition-delay是用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行transition效果,其取值:<time>为数值,单位为s(秒)或者ms(毫秒),其使用和transition-duration极其相似,也可以作用于所有元素,包括:before和:after伪元素。 默认大小是"0",也就是变换立即执行,没有延迟。

    有时我们不只改变一个css效果的属性,而是想改变两个或者多个css属性的transition效果,那么我们只要把几个transition的声明串在一起,用逗号(“,”)隔开,然后各自可以有各自不同的延续时间和其时间的速率变换方式。但需要值得注意的一点:transition-delay与transition-duration的值都是时间,所以要区分它们在连写中的位置,一般浏览器会根据先后顺序决定,第一个可以解析为时间的怭值为transition-duration第二个为transition-delay。如:

    1. a { 
    2.     -moz-transition: background 0.5s ease-in,color 0.3s ease-out; 
    3.     -webkit-transition: background 0.5s ease-in,color 0.3s ease-out; 
    4.     -o-transition: background 0.5s ease-in,color 0.3s ease-out; 
    5.     transition: background 0.5s ease-in,color 0.3s ease-out; 
    6.   } 

    如果你想给元素执行所有transition效果的属性,那么我们还可以利用all属性值来操作,此时他们共享同样的延续时间以及速率变换方式,如:
     

    1. a { 
    2.    -moz-transition: all 0.5s ease-in; 
    3.    -webkit-transition: all 0.5s ease-in; 
    4.    -o-transition: all 0.5s ease-in; 
    5.    transition: all 0.5s ease-in; 
    6.  } 

    综合上述我们可以给transition一个速记法:transition: <property> <duration> <animation type> <delay>如下图所示:

    \

    相对应的一个示例代码:

    1. p { 
    2.   -webkit-transition: all .5s ease-in-out 1s; 
    3.   -o-transition: all .5s ease-in-out 1s; 
    4.   -moz-transition: all .5s ease-in-out 1s; 
    5.   transition: all .5s ease-in-out 1s; 

    浏览器的兼容性:

    \

    因为transition最早是有由webkit内核浏览器提出来的,mozilla和opera都是最近版本才支持这个属性,而我们的大众型浏览器IE全家都是不支持,另外由于各大现代浏览器Firefox,Safari,Chrome,Opera都还不支持W3C的标准写法,所以在应用transition时我们有必要加上各自的前缀,最好在放上我们W3C的标准写法,这样标准的会覆盖前面的写法,只要浏览器支持我们的transition属性,那么这种效果就会自动加上去:

    1. //Mozilla内核 
    2.   -moz-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*  
    3.   //Webkit内核 
    4.   -webkit-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*  
    5.   //Opera 
    6.   -o-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*  
    7.   //W3C 标准 
    8.   transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*  

    通过上面,我想大家对CSS3的Transition属性的使用有一定的概念存在了,下面为了加强大家在这方面的使用,我们一起来看下面的DEMO。我们通过实践来巩固前面的理论知识,也通过实践来加强transition的记忆。

    DEMO一:

    DEMO一我们主要是在一个div中放置了几个小块,分别是对应了transition-timing-function中的几种类型,我们在div的hover状态下,改变其部分属性,从而达到一种动画效果。我们也可以使用jq来点击一个按钮,触发这个div(说简单点就是通过按钮的点击事件给这个div加上一个class,让其子元素都触发相对应的transition动画效果),为了让大家能更好的学习和理解,我把相应的代码贴在这里,感兴趣的朋友就跟着做一下吧,也可以直接把代码复制到你本地页面运行查看效果。

    Html Code:

    1. <a id="timings-demo-btn">click</a> 
    2.  <div id="timings-demo"> 
    3.    <div id="ease" class="demo-box">Ease</div> 
    4.    <div id="ease-in" class="demo-box">Ease-in</div> 
    5.    <div id="ease-out" class="demo-box">Ease-out</div> 
    6.    <div id="ease-in-out" class="demo-box">Ease-in-out</div> 
    7.    <div id="linear" class="demo-box">Linear</div> 
    8.    <div id="cubic-bezier" class="demo-box">Cubic-bezier</div> 
    9.  </div> 

    CSS Code:

    1. #timings-demo { 
    2.      border1px solid #ccc
    3.      padding10px
    4.      height400px
    5.      width400px
    6.    } 
    7.       
    8.   .demo-box { 
    9.      width100px
    10.      height50px
    11.      text-aligncenter
    12.      line-height50px
    13.      text-aligncenter
    14.      color#fff
    15.      background#96c
    16.      -moz-border-radius: 5px
    17.      -webkit-border-radius: 5px
    18.      border-radius: 5px
    19.      -moz-box-shadow: inset 0 0 5px rgba(1021530,0.5); 
    20.      -webkit-box-shadow: inset 0 0 5px rgba(1021530,0.5); 
    21.      box-shadow: inset 0 0 5px rgba(1021530,0.5); 
    22.      margin-bottom10px
    23.   } 
    24.   //ease效果:         
    25.   #ease { 
    26.      -moz-transition: all 5s ease 0.3s; 
    27.      -webkit-transition: all 5s ease 0.3s; 
    28.      -o-transition: all 5s ease 0.3s; 
    29.      transition: all 5s ease 0.3s; 
    30.      background#f36;       
    31.   } 
    32.   //ease-in效果: 
    33.   #ease-in { 
    34.      -moz-transition: all 3s ease-in 0.5s; 
    35.      -webkit-transition: all 3s ease-in 0.5s; 
    36.      -o-transition: all 3s ease-in 0.5s; 
    37.      transition: all 3s ease-in 0.5s; 
    38.      background#369
    39.   } 
    40.   //ease-out效果: 
    41.   #ease-out { 
    42.     -moz-transition: all 5s ease-out 0s; 
    43.     -webkit-transition: all 5s ease-out 0s; 
    44.     -o-transition: all 5s ease-out 0s; 
    45.     transition: all 5s ease-out 0s; 
    46.     background#636;       
    47.   } 
    48.   //ease-in-out效果: 
    49.   #ease-in-out { 
    50.     -moz-transition: all 1s ease-in-out 2s; 
    51.     -webkit-transition: all 1s ease-in-out 2s; 
    52.     -o-transition: all 1s ease-in-out 2s; 
    53.     transition: all 1s ease-in-out 2s; 
    54.     background#3e6
    55.   } 
    56.   //linear效果: 
    57.   #linear { 
    58.     -moz-transition: all 6s linear 0s; 
    59.     -webkit-transition: all 6s linear 0s; 
    60.     -o-transition: all 6s linear 0s; 
    61.     transition: all 6s linear 0s; 
    62.     background#999
    63.   } 
    64.   //cubic-bezier效果: 
    65.   #cubic-bezier { 
    66.     -moz-transition: all 4s cubic-bezier 1s; 
    67.     -webkit-transition: all 4s cubic-bezier 1s; 
    68.     -o-transition: all 4s cubic-bezier 1s; 
    69.     transition: all 4s cubic-bezier 1s; 
    70.     background#6d6
    71.   } 
    72.   //hover状态下或单击click按钮后demo-box产生属性变化 
    73.   #timings-demo.timings-demo-hover .demo-box, 
    74.     #timings-demo:hover .demo-box { 
    75.     -moz-transform: rotate(360deg) scale(1.2); 
    76.     -webkit-transform: rotate(360deg) scale(1.2); 
    77.     -o-transform: rotate(360deg) scale(1.2); 
    78.     transform: rotate(360deg) scale(1.2); 
    79.     background#369
    80.     border1px solid rgba(255,230,255,08); 
    81.     -moz-border-radius: 25px
    82.     -webkit-border-radius: 25px
    83.     border-radius: 25px
    84.     margin-left280px
    85.     height30px
    86.     line-height30px
    87.     margin-bottom15px
    88.   } 

    使用单击事件给dimings-demo加上一个timings-demo-hover的class名,使用demo-bxo产生属性变化

    1. $(document).ready(function(){ 
    2.     $("#timings-demo-btn").toggle( 
    3.        function(){ 
    4.          $(this).next("div#timings-demo").addClass("timings-demo-hover"); 
    5.        },function(){ 
    6.          $(this).next("div#timings-demo").removeClass("timings-demo-hover"); 
    7.     }); 
    8.  }); 

    我们来看看其效果图

    \未改变属性效果

    \正在变换中

    \执行完动画后的最终效果

    上图是鼠标移动到#timings-demo的div产生的效果变换示意图,你单击“click”按钮同样会产生上面的一个动画效应,为了节约空间,这里不在贴出示意图。

    DEMO二:

    我们在来看另外一个DEMO,这个示例是通过CSS3的transition模仿制作jQuery的slideshow效果,当然这种效果跟js和jQ制作出来的是没得比,但有时还是可以用一用的,以前腾讯就使用过这样的一个效果。我们这个DEMO实现的效果原理跟上一个DEMO极其相似,这里我们是通过select的change事件来触slideshow的CSS3属性变化,这里应用到一部分jQuery,主要是制作数字切换和前一张下一张的按钮,以及select的change事件。下面我把代码贴出以供大家参考,如果你跟着做了的话,你会觉得CSS3的transition真的是魅力是无穷的。

    Html Code:

    1. <div id="demoSliderContainer"> 
    2.     <ul id="demoSlider" class="slide-images"> 
    3.       <li class="slide-image"> 
    4.         <img src="/images/monstersinc.jpg" alt="monsters inc" /> 
    5.         <span>Monsters Inc</span> 
    6.       </li> 
    7.       <li class="slide-image"> 
    8.         <img src="/images/nemo.jpg" alt="nemo" /> 
    9.         <span>Nemo</span> 
    10.       </li> 
    11.       <li class="slide-image"> 
    12.         <img src="/images/up.jpg" alt="up" /> 
    13.         <span>Up</span> 
    14.       </li> 
    15.       <li class="slide-image"> 
    16.         <img src="/images/walle.jpg" alt="walle" /> 
    17.         <span>Wall-E</span> 
    18.       </li> 
    19.     </ul> 
    20.     <div class="options"> 
    21.       <a href="javascript:;" class="prevSlide">Prev</a> 
    22.       <span class="slide-pager"> 
    23.         <a href="" class="javascript:;">1</a> 
    24.         <a href="" class="javascript:;">2</a> 
    25.         <a href="" class="javascript:;">3</a> 
    26.         <a href="" class="javascript:;">4</a> 
    27.       </span> 
    28.       <a href="javascript:;" class="nextSlide">Next</a> 
    29.     </div> 
    30.   </div> 
    31.   <div id="options"> 
    32.      <label for="transitionEffect">Transition effect :</label> 
    33.      <select id="transitionEffect"> 
    34.         <option value="transition-opacity">opacity fade</option> 
    35.         <option value="transition-left">left slide</option> 
    36.         <option value="transition-right">right slide</option> 
    37.         <option value="transition-top">top slide</option> 
    38.         <option value="transition-bottom">bottom slide</option> 
    39.         <option value="transition-zoom">zoom</option> 
    40.         <option value="transition-dezoom">de-zoom</option> 
    41.         <option value="transition-cornerzoom">corner zoom</option> 
    42.         <option value="transition-rotate">rotate</option> 
    43.       </select> 
    44.   </div> 

    CSS Code:

    1. #demoSliderContainer { 
    2.   background#000
    3.   -moz-box-shadow: 1px 1px 5px #000
    4.   -webkit-box-shadow: 1px 1px 5px #000
    5.   box-shadow: 1px 1px 5px #000
    6.   padding0
    7.   overflowauto
    8.   margin10px auto
    9.   width560px
    10.      
    11. #demoSlider { 
    12.   border1px solid #000
    13.   border-width5px 5px 0
    14.   height220px
    15.   margin0 auto
    16.   width550px
    17.   overflowhidden
    18.   positionrelative
    19.      
    20. .slide-images .slide-image { 
    21.   positionabsolute
    22.      
    23. .slide-images .slide-image img { 
    24.   z-index2
    25.      
    26. .slide-images .slide-image span { 
    27.   background: rgba(0,0,0,0.3); 
    28.   -moz-border-radius: 5px 0 0 0
    29.   -webkit-border-radius: 5px 0 0 0
    30.   border-radius: 5px 0 0 0
    31.   bottom: 4px
    32.   color: rgba(255,255,255,0.8); 
    33.   font-size14px
    34.   font-weightbold
    35.   padding5px 10px
    36.   positionabsolute
    37.   right: 0
    38.   z-index3
    39. .slide-images .slide-image.current img { 
    40.   z-index12
    41.      
    42. .slide-images .slide-image.current span { 
    43.   z-index13
    44.      
    45. #demoSliderContainer .options { 
    46.   padding3px 10px
    47.   text-aligncenter
    48. #demoSliderContainer .options a { 
    49.   color#91BECC
    50.   font-family: Georgia,Serif; 
    51.   font-size12px
    52.   font-weightbold
    53.   text-decorationnone
    54. #demoSliderContainer .options a:hover { 
    55.   color#D3E5EB
    56. #demoSliderContainer .slide-pager a { 
    57.   -moz-transition-duration: 0.5s; 
    58.   -webkit-transition-duration: 0.5s; 
    59.   -o-transition-duration: 0.5s; 
    60.   transition-duration: 0.5s; 
    61. #demoSliderContainer .slide-pager a.current { 
    62.   background-color#91BECC
    63.   border-radius: 5px 5px 5px 5px
    64.   colorblack
    65.   padding0 4px
    66. #demoSliderContainer .options .prevSlide { 
    67.   floatleft
    68. #demoSliderContainer .options .nextSlide { 
    69.   floatright
    70.     
    71.  /*transition effect*/ 
    72. .slide-images .slide-image, 
    73. .slide-images .slide-image img { 
    74.    -moz-transition-duration: 1.5s; 
    75.    -webkit-transition-duration: 1.5s; 
    76.    -otransition-duration: 1.5s; 
    77.    transition-duration: 1.5s; 
    78.  } 
    79.      
    80.  .slide-images.transition-opacity .slide-image { 
    81.    opacity: 0
    82.    width0
    83.  } 
    84.      
    85.  .slide-images.transition-opacity .slide-image.current { 
    86.    opacity: 1
    87.    width550px
    88.  } 
    89.     
    90.  .slide-images.transition-left .slide-image { 
    91.    left: -550px
    92.    opacity: 0
    93.  } 
    94.      
    95.  .slide-images.transition-left .slide-image.current { 
    96.    left: 0
    97.    opacity: 1
    98.  } 
    99.      
    100.  .slide-images.transition-right .slide-image { 
    101.    right: -550px
    102.    opacity: 0
    103.  } 
    104.  .slide-images.transition-right .slide-image.current { 
    105.    right: 0
    106.    opacity: 1
    107.  } 
    108.      
    109.      
    110.  .slide-images.transition-top .slide-image { 
    111.    opacity: 0
    112.    top: -220px
    113.  } 
    114.  .slide-images.transition-top .slide-image.current { 
    115.    opacity: 1
    116.    top: 0
    117.  } 
    118.      
    119.  .slide-images.transition-bottom .slide-image { 
    120.    opacity: 0
    121.    bottom: -220px
    122.  } 
    123.  .slide-images.transition-bottom .slide-image.current { 
    124.    opacity: 1
    125.    bottom: 0
    126.  } 
    127.      
    128.  .slide-images.transition-cornerzoom .slide-image { 
    129.    opacity: 0
    130.  } 
    131.      
    132.  .slide-images.transition-cornerzoom .slide-image.current { 
    133.    opacity: 1
    134.  } 
    135.      
    136.  .slide-images.transition-cornerzoom .slide-image img { 
    137.    width0
    138.  } 
    139.      
    140.  .slide-images.transition-cornerzoom .slide-image.current img { 
    141.    width550px
    142.  } 
    143.      
    144.  .slide-images.transition-zoom .slide-image { 
    145.    opacity: 0
    146.  } 
    147.  .slide-images.transition-zoom .slide-image.current { 
    148.    opacity: 1
    149.  } 
    150.  .slide-images.transition-zoom .slide-image img { 
    151.    left: -275px
    152.    positionrelative
    153.    top: -110px
    154.    width1100px
    155.  } 
    156.  .slide-images.transition-zoom .slide-image.current img { 
    157.    left: 0
    158.    top: 0
    159.    width550px
    160.  } 
    161.      
    162.  .slide-images.transition-dezoom .slide-image { 
    163.    -moz-box-shadow: 2px 2px 8px black
    164.    -webkit-box-shadow: 2px 2px 8px black
    165.    box-shadow: 2px 2px 8px black
    166.    opacity: 0
    167.  } 
    168.  .slide-images.transition-dezoom .slide-image.current { 
    169.    opacity: 1
    170.  } 
    171.  .slide-images.transition-dezoom .slide-image img { 
    172.    left: 275px
    173.    positionrelative
    174.    top: 110px
    175.    width0
    176.  } 
    177.  .slide-images.transition-dezoom .slide-image.current img { 
    178.    left: 0
    179.    top: 0
    180.    width550px
    181.  } 
    182.     
    183.  .slide-images.transition-rotate .slide-image { 
    184.    opacity: 0
    185.  } 
    186.  .slide-images.transition-rotate .slide-image.current { 
    187.    opacity: 1
    188.  } 
    189.  .slide-images.transition-rotate .slide-image img { 
    190.    width550
    191.    height220px
    192.    positionrelative
    193.    left: -550px
    194.    top: -220px
    195.     
    196.   } 
    197.   .slide-images.transition-rotate .slide-image.current img { 
    198.     width550px
    199.     height220px
    200.     left: 0
    201.     top: 0
    202.     -moz-transform: rotate(1440deg); 
    203.     -webkit-transform: rotate(1440deg); 
    204.     -o-transform: rotate(1440deg); 
    205.     transform: rotate(1440deg); 
    206.   } 
    207.      
    208.      
    209.   #options { 
    210.      margin20px auto
    211.      padding5px
    212.      width550px
    213.   } 

    jQuery Code:

    1.     $(document).ready(function(){ 
    2.       $(".slide-images").each(function(){ 
    3.         var slider = $(this); 
    4.         var slides = $(".slide-image",slider); 
    5.         var sliderPages = $(".slide-pager"); 
    6.          
    7.         //Slide Navigation 
    8.          
    9.         var currentSlideNum = 0; 
    10.         slides.removeClass("current"); 
    11.         slides.eq(currentSlideNum).addClass("current"); 
    12.         sliderPages.each(function(){ 
    13.           var pages = $("a",this); 
    14.           pages.removeClass("current"); 
    15.           pages.eq(currentSlideNum).addClass("current"); 
    16.         }); 
    17.          
    18.         var goToSlide = function(slideNum) { 
    19.           slides.eq(currentSlideNum).removeClass("current"); 
    20.           slides.eq(slideNum).addClass("current"); 
    21.           sliderPages.each(function(){ 
    22.   var pages = $("a"this); 
    23.   pages.eq(currentSlideNum).removeClass("current"); 
    24.   pages.eq(slideNum).addClass("current"); 
    25.           }); 
    26.           currentSlideNum = slideNum; 
    27.         }; 
    28.          
    29.         var nextSlide = function() { 
    30.           var nextSlideNum = currentSlideNum + 1; 
    31.           if(nextSlideNum >= slides.size())  
    32.   nextSlideNum = 0; 
    33.   goToSlide(nextSlideNum); 
    34.            
    35.         };  
    36.          
    37.         var prevSlide = function() { 
    38.           var prevSlideNum = currentSlideNum - 1; 
    39.           if(prevSlideNum < 0) 
    40.   prevSlideNum = slides.size() - 1; 
    41.   goToSlide(prevSlideNum); 
    42.            
    43.         }; 
    44.          
    45.         //transition effects 
    46.         var setTransitionEffect = function(transitionEffect) { 
    47.           slider.attr("class","slide-images "+ transitionEffect); 
    48.         }; 
    49.          
    50.         $("#transitionEffect").change(function(){ 
    51.           setTransitionEffect($(this).val()); 
    52.         }).change(); 
    53.          
    54.         //Navigation binding 
    55.          
    56.         $(".prevSlide").click(prevSlide); 
    57.         $(".nextSlide").click(nextSlide); 
    58.         $(".slide-pager a").each(function(i){ 
    59.           if(i >= slides.size()) return false
    60.           $(this).click(function(){ 
    61.   goToSlide(i); 
    62.           }); 
    63.         }); 
    64.          
    65.         //Auto next slide 
    66.          
    67.         var lastHumanNav = 0; 
    68.         $(".prevSlide, .nextSlide, .slide-pager a").click(function(){ 
    69.           lastHumanNav = new Date().getTime(); 
    70.         }); 
    71.         setInterval(function(){ 
    72.           var now = new Date().getTime(); 
    73.           if(now - lastHumanNav > 5000) 
    74.   nextSlide(); 
    75.         },5000); 
    76.       }); 
    77.     }); 
    78.      

    记得在你的本地页面头部加上jQuery的版本库文件。

    效果示意图:

    \

    DEMO二思路来自于Greweb.fr并在其基础上增加了right silde,bottom silde,rotate三种效果,如果你感兴趣的话可以在这个基础上增加更多的slideshow效果,比如利用transform的scale,skew等制作出更出色的效果。

    那么今天我们关于CSS3transition就简单的介绍到这里,下一节我们一起接着学习CSS3中动画属性的最后一个属性动画(animation),感兴趣的可以观注本站关于CSS3的最新更新情况。


本文来源地址:http://www.w3cplus.com/content/css3-transition/