优定义网

CSS3 Transition

凤梦洁 发表于 2018-5-26 22:24:09 | 显示全部楼层 |阅读模式
  上一节花了大篇幅整理了CSS3中动画属性中的Transform,今天我们接着一起来看CSS3动画属性中的另一个属性Transition。
  W3C标准中对css3的transition这是样描述的:“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 | [  ] [ ','  ]*
复制代码
  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,>
  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是用来指定元素 转换过程的持续时间,取值:为数值,单位为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.
cubic-bezier.png
  其他几个属性的示意图:
transition-timing-function.png
  四、transition-delay:
  语法:
  1. transition-delay : <time> [, <time>]*
复制代码
  transition-delay是用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行transition效果,其取值:为数值,单位为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:    如下图所示:
transition-suji.png
  相对应的一个示例代码:
  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;
  6.   }
复制代码
  浏览器的兼容性:
transition-browers.png
  因为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.   border: 1px solid #ccc;
  3.   padding: 10px;
  4.   height: 400px;
  5.   width: 400px;
  6.   }
  7.   .demo-box {
  8.   width: 100px;
  9.   height: 50px;
  10.   text-align: center;
  11.   line-height: 50px;
  12.   text-align: center;
  13.   color: #fff;
  14.   background: #96c;
  15.   -moz-border-radius: 5px;
  16.   -webkit-border-radius: 5px;
  17.   border-radius: 5px;
  18.   -moz-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
  19.   -webkit-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
  20.   box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
  21.   margin-bottom: 10px;
  22.   }
  23.   //ease效果:
  24.   #ease {
  25.   -moz-transition: all 5s ease 0.3s;
  26.   -webkit-transition: all 5s ease 0.3s;
  27.   -o-transition: all 5s ease 0.3s;
  28.   transition: all 5s ease 0.3s;
  29.   background: #f36;
  30.   }
  31.   //ease-in效果:
  32.   #ease-in {
  33.   -moz-transition: all 3s ease-in 0.5s;
  34.   -webkit-transition: all 3s ease-in 0.5s;
  35.   -o-transition: all 3s ease-in 0.5s;
  36.   transition: all 3s ease-in 0.5s;
  37.   background: #369;
  38.   }
  39.   //ease-out效果:
  40.   #ease-out {
  41.   -moz-transition: all 5s ease-out 0s;
  42.   -webkit-transition: all 5s ease-out 0s;
  43.   -o-transition: all 5s ease-out 0s;
  44.   transition: all 5s ease-out 0s;
  45.   background: #636;
  46.   }
  47.   //ease-in-out效果:
  48.   #ease-in-out {
  49.   -moz-transition: all 1s ease-in-out 2s;
  50.   -webkit-transition: all 1s ease-in-out 2s;
  51.   -o-transition: all 1s ease-in-out 2s;
  52.   transition: all 1s ease-in-out 2s;
  53.   background: #3e6;
  54.   }
  55.   //linear效果:
  56.   #linear {
  57.   -moz-transition: all 6s linear 0s;
  58.   -webkit-transition: all 6s linear 0s;
  59.   -o-transition: all 6s linear 0s;
  60.   transition: all 6s linear 0s;
  61.   background: #999;
  62.   }
  63.   //cubic-bezier效果:
  64.   #cubic-bezier {
  65.   -moz-transition: all 4s cubic-bezier 1s;
  66.   -webkit-transition: all 4s cubic-bezier 1s;
  67.   -o-transition: all 4s cubic-bezier 1s;
  68.   transition: all 4s cubic-bezier 1s;
  69.   background: #6d6;
  70.   }
  71.   //hover状态下或单击click按钮后demo-box产生属性变化
  72.   #timings-demo.timings-demo-hover .demo-box,
  73.   #timings-demo:hover .demo-box {
  74.   -moz-transform: rotate(360deg) scale(1.2);
  75.   -webkit-transform: rotate(360deg) scale(1.2);
  76.   -o-transform: rotate(360deg) scale(1.2);
  77.   transform: rotate(360deg) scale(1.2);
  78.   background: #369;
  79.   border: 1px solid rgba(255,230,255,08);
  80.   -moz-border-radius: 25px;
  81.   -webkit-border-radius: 25px;
  82.   border-radius: 25px;
  83.   margin-left: 280px;
  84.   height: 30px;
  85.   line-height: 30px;
  86.   margin-bottom: 15px;
  87.   }
复制代码
  使用单击事件给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.   });
复制代码
  我们来看看其效果图
transition-demo1.png

未改变属性效果

2.jpg

正在变换中

transition-demo-1-3.png

执行完动画后的最终效果

  上图是鼠标移动到#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.   padding: 0;
  7.   overflow: auto;
  8.   margin: 10px auto;
  9.   width: 560px;
  10.   }
  11.   #demoSlider {
  12.   border: 1px solid #000;
  13.   border-width: 5px 5px 0;
  14.   height: 220px;
  15.   margin: 0 auto;
  16.   width: 550px;
  17.   overflow: hidden;
  18.   position:>
  19.   }
  20.   .slide-images .slide-image {
  21.   position: absolute;
  22.   }
  23.   .slide-images .slide-image img {
  24.   z-index: 2;
  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-size: 14px;
  34.   font-weight: bold;
  35.   padding: 5px 10px;
  36.   position: absolute;
  37.   right: 0;
  38.   z-index: 3;
  39.   }
  40.   .slide-images .slide-image.current img {
  41.   z-index: 12;
  42.   }
  43.   .slide-images .slide-image.current span {
  44.   z-index: 13;
  45.   }
  46.   #demoSliderContainer .options {
  47.   padding: 3px 10px;
  48.   text-align: center;
  49.   }
  50.   #demoSliderContainer .options a {
  51.   color: #91BECC;
  52.   font-family: Georgia,Serif;
  53.   font-size: 12px;
  54.   font-weight: bold;
  55.   text-decoration: none;
  56.   }
  57.   #demoSliderContainer .options a:hover {
  58.   color: #D3E5EB;
  59.   }
  60.   #demoSliderContainer .slide-pager a {
  61.   -moz-transition-duration: 0.5s;
  62.   -webkit-transition-duration: 0.5s;
  63.   -o-transition-duration: 0.5s;
  64.   transition-duration: 0.5s;
  65.   }
  66.   #demoSliderContainer .slide-pager a.current {
  67.   background-color: #91BECC;
  68.   border-radius: 5px 5px 5px 5px;
  69.   color: black;
  70.   padding: 0 4px;
  71.   }
  72.   #demoSliderContainer .options .prevSlide {
  73.   float: left;
  74.   }
  75.   #demoSliderContainer .options .nextSlide {
  76.   float: right;
  77.   }
  78.   /*transition effect*/
  79.   .slide-images .slide-image,
  80.   .slide-images .slide-image img {
  81.   -moz-transition-duration: 1.5s;
  82.   -webkit-transition-duration: 1.5s;
  83.   -otransition-duration: 1.5s;
  84.   transition-duration: 1.5s;
  85.   }
  86.   .slide-images.transition-opacity .slide-image {
  87.   opacity: 0;
  88.   width: 0;
  89.   }
  90.   .slide-images.transition-opacity .slide-image.current {
  91.   opacity: 1;
  92.   width: 550px;
  93.   }
  94.   .slide-images.transition-left .slide-image {
  95.   left: -550px;
  96.   opacity: 0;
  97.   }
  98.   .slide-images.transition-left .slide-image.current {
  99.   left: 0;
  100.   opacity: 1;
  101.   }
  102.   .slide-images.transition-right .slide-image {
  103.   right: -550px;
  104.   opacity: 0;
  105.   }
  106.   .slide-images.transition-right .slide-image.current {
  107.   right: 0;
  108.   opacity: 1;
  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.   .slide-images.transition-bottom .slide-image {
  119.   opacity: 0;
  120.   bottom: -220px;
  121.   }
  122.   .slide-images.transition-bottom .slide-image.current {
  123.   opacity: 1;
  124.   bottom: 0;
  125.   }
  126.   .slide-images.transition-cornerzoom .slide-image {
  127.   opacity: 0;
  128.   }
  129.   .slide-images.transition-cornerzoom .slide-image.current {
  130.   opacity: 1;
  131.   }
  132.   .slide-images.transition-cornerzoom .slide-image img {
  133.   width: 0;
  134.   }
  135.   .slide-images.transition-cornerzoom .slide-image.current img {
  136.   width: 550px;
  137.   }
  138.   .slide-images.transition-zoom .slide-image {
  139.   opacity: 0;
  140.   }
  141.   .slide-images.transition-zoom .slide-image.current {
  142.   opacity: 1;
  143.   }
  144.   .slide-images.transition-zoom .slide-image img {
  145.   left: -275px;
  146.   position:>
  147.   top: -110px;
  148.   width: 1100px;
  149.   }
  150.   .slide-images.transition-zoom .slide-image.current img {
  151.   left: 0;
  152.   top: 0;
  153.   width: 550px;
  154.   }
  155.   .slide-images.transition-dezoom .slide-image {
  156.   -moz-box-shadow: 2px 2px 8px black;
  157.   -webkit-box-shadow: 2px 2px 8px black;
  158.   box-shadow: 2px 2px 8px black;
  159.   opacity: 0;
  160.   }
  161.   .slide-images.transition-dezoom .slide-image.current {
  162.   opacity: 1;
  163.   }
  164.   .slide-images.transition-dezoom .slide-image img {
  165.   left: 275px;
  166.   position:>
  167.   top: 110px;
  168.   width: 0;
  169.   }
  170.   .slide-images.transition-dezoom .slide-image.current img {
  171.   left: 0;
  172.   top: 0;
  173.   width: 550px;
  174.   }
  175.   .slide-images.transition-rotate .slide-image {
  176.   opacity: 0;
  177.   }
  178.   .slide-images.transition-rotate .slide-image.current {
  179.   opacity: 1;
  180.   }
  181.   .slide-images.transition-rotate .slide-image img {
  182.   width: 550;
  183.   height: 220px;
  184.   position:>
  185.   left: -550px;
  186.   top: -220px;
  187.   }
  188.   .slide-images.transition-rotate .slide-image.current img {
  189.   width: 550px;
  190.   height: 220px;
  191.   left: 0;
  192.   top: 0;
  193.   -moz-transform: rotate(1440deg);
  194.   -webkit-transform: rotate(1440deg);
  195.   -o-transform: rotate(1440deg);
  196.   transform: rotate(1440deg);
  197.   }
  198.   #options {
  199.   margin: 20px auto;
  200.   padding: 5px;
  201.   width: 550px;
  202.   }
复制代码
  jQuery Code:
  
  1. <script type="text/javascript">
  2.     $(document).ready(function(){
  3.       $(".slide-images").each(function(){
  4.         var slider = $(this);
  5.         var slides = $(".slide-image",slider);
  6.         var sliderPages = $(".slide-pager");
  7.         
  8.         //Slide Navigation
  9.         
  10.         var currentSlideNum = 0;
  11.         slides.removeClass("current");
  12.         slides.eq(currentSlideNum).addClass("current");
  13.         sliderPages.each(function(){
  14.           var pages = $("a",this);
  15.           pages.removeClass("current");
  16.           pages.eq(currentSlideNum).addClass("current");
  17.         });
  18.         
  19.         var goToSlide = function(slideNum) {
  20.           slides.eq(currentSlideNum).removeClass("current");
  21.           slides.eq(slideNum).addClass("current");
  22.           sliderPages.each(function(){
  23.             var pages = $("a", this);
  24.             pages.eq(currentSlideNum).removeClass("current");
  25.             pages.eq(slideNum).addClass("current");
  26.           });
  27.           currentSlideNum = slideNum;
  28.         };
  29.         
  30.         var nextSlide = function() {
  31.           var nextSlideNum = currentSlideNum + 1;
  32.           if(nextSlideNum >= slides.size())
  33.             nextSlideNum = 0;
  34.             goToSlide(nextSlideNum);
  35.          
  36.         };
  37.         
  38.         var prevSlide = function() {
  39.           var prevSlideNum = currentSlideNum - 1;
  40.           if(prevSlideNum < 0)
  41.             prevSlideNum = slides.size() - 1;
  42.             goToSlide(prevSlideNum);
  43.          
  44.         };
  45.         
  46.         //transition effects
  47.         var setTransitionEffect = function(transitionEffect) {
  48.           slider.attr("class","slide-images "+ transitionEffect);
  49.         };
  50.         
  51.         $("#transitionEffect").change(function(){
  52.           setTransitionEffect($(this).val());
  53.         }).change();
  54.         
  55.         //Navigation binding
  56.         
  57.         $(".prevSlide").click(prevSlide);
  58.         $(".nextSlide").click(nextSlide);
  59.         $(".slide-pager a").each(function(i){
  60.           if(i >= slides.size()) return false;
  61.           $(this).click(function(){
  62.             goToSlide(i);
  63.           });
  64.         });
  65.         
  66.         //Auto next slide
  67.         
  68.         var lastHumanNav = 0;
  69.         $(".prevSlide, .nextSlide, .slide-pager a").click(function(){
  70.           lastHumanNav = new Date().getTime();
  71.         });
  72.         setInterval(function(){
  73.           var now = new Date().getTime();
  74.           if(now - lastHumanNav > 5000)
  75.             nextSlide();
  76.         },5000);
  77.       });
  78.     });
  79.    
  80. </script>
复制代码
  记得在你的本地页面头部加上jQuery的版本库文件。
  效果示意图:
1.png
  DEMO二思路来自于Greweb.fr并在其基础上增加了right silde,bottom silde,rotate三种效果,如果你感兴趣的话可以在这个基础上增加更多的slideshow效果,比如利用transform的scale,skew等制作出更出色的效果。
  上面我主要介绍了两个实例,如果你对这两个实例还不过瘾的话,下面有更多的关于transition的实例:DEMO三、DEMO四。
  那么今天我们关于CSS3的transition就简单的介绍到这里,下一节我们一起接着学习CSS3中动画属性的最后一个属性动画(animation),感兴趣的可以观注本站关于CSS3的最新更新情况。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

精华推荐
  • 一个人开始废掉的3种迹象

    一个人开始废掉的3种迹象

  • 从零到60秒的惬意冰镇啤酒

    从零到60秒的惬意冰镇啤酒

  • 马云、马化腾、王石都弃之不用的人,有一个共同点

    马云、马化腾、王石都弃之不用的人,有一个

  • 哥特式高迪凳子

    哥特式高迪凳子

  • 千亿小米,雷军逆袭

    千亿小米,雷军逆袭

  • 她一战赚了几十亿,她说:世界上最好的生意有三种

    她一战赚了几十亿,她说:世界上最好的生意有

  • 雷军:合伙人比制度更重要!

    雷军:合伙人比制度更重要!

  • 一个美美的令人喜欢的自行车铃

    一个美美的令人喜欢的自行车铃

QQ客服热线
QQ:1090281100 周一至周日:09:00 - 21:00
WeChat:dianlingkeji
Email:kaixin1069@vip.qq.com

优定义logo

勿要吝啬你无形资产,请为创新续源,知识、点子、灵感、经验、需求等均是创新源泉,你不经意的一句话将是另一个人的灵感。明天的明天,还有明天,我们应该把握今天,每一个今天,都有一个新的事物在出现,今天的漠视明天的落后,不浪费每一个学习的时刻,学习助力非凡。

技术支持 Discuz! X3.4 - 3.5 beta © 2001-2018 Comsenz Inc.

小黑屋|手机版|优定义 ( 粤ICP备16085288号-2 )|申请友链|网站地图

粤公网安备 44011102001144 号 GMT+8, 2018-10-18 09:46 , Processed in 0.105273 second(s), 29 queries .

快速回复 返回顶部 返回列表