• CSS3 Transition


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

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

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

    语法:

      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:

    语法:

      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:

    语法:

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

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

    三、transition-timing-function:

    语法:

      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(x1, y1, x2, y2)

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

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

    图上有四点,P0 P1 P2 P3,其中P0、P3是默认的点,对应了[0,0], [1,1]。而剩下的P1、P2两点则是我们通过cubic-bezier()自定义的。

    其他几个属性的示意图:

    四、transition-delay:

    语法:

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

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

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

      a {
        -moz-transition: background 0.5s ease-in,color 0.3s ease-out;
        -webkit-transition: background 0.5s ease-in,color 0.3s ease-out;
        -o-transition: background 0.5s ease-in,color 0.3s ease-out;
        transition: background 0.5s ease-in,color 0.3s ease-out;
      }
    

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

      a {
        -moz-transition: all 0.5s ease-in;
        -webkit-transition: all 0.5s ease-in;
        -o-transition: all 0.5s ease-in;
        transition: all 0.5s ease-in;
      }
    

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

    相对应的一个示例代码:

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

    浏览器的兼容性:

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

       //Mozilla内核
       -moz-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* 
       //Webkit内核
       -webkit-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* 
       //Opera
       -o-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* 
       //W3C 标准
       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 <style type="text/css">
     2 #timings-demo {
     3     border: 1px solid #ccc;
     4     padding: 10px;
     5     height: 400px;
     6      400px;
     7 }
     8 .demo-box {
     9      100px;
    10     height: 50px;
    11     text-align: center;
    12     line-height: 50px;
    13     text-align: center;
    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(102, 153, 0,0.5);
    20     -webkit-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
    21     box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
    22     margin-bottom: 10px;
    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效果:  4个数值可以随意设置 范围[0,1]
    66     -moz-transition: all 4s cubic-bezier(0.5, 0.75, 0.2, 0.7) 1s;
    67     -webkit-transition: all 4s cubic-bezier(0.5, 0.75, 0.2, 0.7) 1s;
    68     -o-transition: all 4s cubic-bezier(0.5, 0.75, 0.2, 0.7) 1s;
    69     transition: all 4s cubic-bezier(0.5, 0.75, 0.2, 0.7) 1s;
    70     background: #6d6;
    71 }
    72 #timings-demo.timings-demo-hover .demo-box, #timings-demo:hover .demo-box {
    73     //hover状态下或单击click按钮后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 }
    88 </style>
    
    
    

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

    
    
    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真的是魅力是无穷的。

      1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
      2 <html xmlns="http://www.w3.org/1999/xhtml">
      3 <head>
      4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
      5 <script type="text/javascript" src="jquery-1.3.2.min.js">
      6 </script>
      7 <script type="text/javascript">
      8     $(document).ready(function() {
      9         $(".slide-images").each(function() {
     10             var slider = $(this);
     11             var slides = $(".slide-image", slider);
     12             var sliderPages = $(".slide-pager");
     13 
     14             //Slide Navigation
     15             var currentSlideNum = 0;
     16             slides.removeClass("current");
     17             slides.eq(currentSlideNum).addClass("current");
     18             sliderPages.each(function() {
     19                 var pages = $("a", this);
     20                 pages.removeClass("current");
     21                 pages.eq(currentSlideNum).addClass("current");
     22             });
     23 
     24             var goToSlide = function(slideNum) {
     25                 slides.eq(currentSlideNum).removeClass("current");
     26                 slides.eq(slideNum).addClass("current");
     27                 sliderPages.each(function() {
     28                     var pages = $("a", this);
     29                     pages.eq(currentSlideNum).removeClass("current");
     30                     pages.eq(slideNum).addClass("current");
     31                 });
     32                 currentSlideNum = slideNum;
     33             };
     34 
     35             var nextSlide = function() {
     36                 var nextSlideNum = currentSlideNum + 1;
     37                 if (nextSlideNum >= slides.size()) nextSlideNum = 0;
     38                 goToSlide(nextSlideNum);
     39 
     40             };
     41 
     42             var prevSlide = function() {
     43                 var prevSlideNum = currentSlideNum - 1;
     44                 if (prevSlideNum < 0) prevSlideNum = slides.size() - 1;
     45                 goToSlide(prevSlideNum);
     46 
     47             };
     48 
     49             //transition effects
     50             var setTransitionEffect = function(transitionEffect) {
     51                 slider.attr("class", "slide-images " + transitionEffect);
     52             };
     53 
     54             $("#transitionEffect").change(function() {
     55                 setTransitionEffect($(this).val());
     56             }).change();
     57 
     58             //Navigation binding
     59             $(".prevSlide").click(prevSlide);
     60             $(".nextSlide").click(nextSlide);
     61             $(".slide-pager a").each(function(i) {
     62                 if (i >= slides.size()) return false;
     63                 $(this).click(function() {
     64                     goToSlide(i);
     65                 });
     66             });
     67 
     68             //Auto next slide
     69             var lastHumanNav = 0;
     70             $(".prevSlide, .nextSlide, .slide-pager a").click(function() {
     71                 lastHumanNav = new Date().getTime();
     72             });
     73             setInterval(function() {
     74                 var now = new Date().getTime();
     75                 if (now - lastHumanNav > 5000) nextSlide();
     76             },
     77             5000);
     78         });
     79     });
     80 </script>
     81 <style type="text/css">
     82 ul {
     83     padding:0;
     84 }
     85 #demoSliderContainer {
     86     background: #000;
     87     -moz-box-shadow: 1px 1px 5px #000;
     88     -webkit-box-shadow: 1px 1px 5px #000;
     89     box-shadow: 1px 1px 5px #000;
     90     padding: 0;
     91     overflow: auto;
     92     margin: 10px auto;
     93      600px;
     94 }
     95 #demoSlider {
     96     border: 1px solid #000;
     97     border- 5px 5px 0;
     98     height: 220px;
     99     margin: 0 auto;
    100      550px;
    101     overflow: hidden;
    102     position: relative;
    103 }
    104 .slide-images .slide-image {
    105     position: absolute;
    106 }
    107 .slide-images .slide-image img {
    108     z-index: 2;
    109 }
    110 .slide-images .slide-image span {
    111     background: rgba(0,0,0,0.3);
    112     -moz-border-radius: 5px 0 0 0;
    113     -webkit-border-radius: 5px 0 0 0;
    114     border-radius: 5px 0 0 0;
    115     bottom: 4px;
    116     color: rgba(255,255,255,0.8);
    117     font-size: 14px;
    118     font-weight: bold;
    119     padding: 5px 10px;
    120     position: absolute;
    121     right: 0;
    122     z-index: 3;
    123 }
    124 .slide-images .slide-image.current img {
    125     z-index: 12;
    126 }
    127 .slide-images .slide-image.current span {
    128     z-index: 13;
    129 }
    130 #demoSliderContainer .options {
    131     padding: 3px 10px;
    132     text-align: center;
    133 }
    134 #demoSliderContainer .options a {
    135     color: #91BECC;
    136     font-family: Georgia, Serif;
    137     font-size: 12px;
    138     font-weight: bold;
    139     text-decoration: none;
    140 }
    141 #demoSliderContainer .options a:hover {
    142     color: #D3E5EB;
    143 }
    144 #demoSliderContainer .slide-pager a {
    145     -moz-transition-duration: 0.5s;
    146     -webkit-transition-duration: 0.5s;
    147     -o-transition-duration: 0.5s;
    148     transition-duration: 0.5s;
    149 }
    150 #demoSliderContainer .slide-pager a.current {
    151     background-color: #91BECC;
    152     border-radius: 5px 5px 5px 5px;
    153     color: black;
    154     padding: 0 4px;
    155 }
    156 #demoSliderContainer .options .prevSlide {
    157     float: left;
    158 }
    159 #demoSliderContainer .options .nextSlide {
    160     float: right;
    161 }
    162 /*transition effect*/
    163 .slide-images .slide-image,
    164 .slide-images .slide-image img {
    165     -moz-transition-duration: 1.5s;
    166     -webkit-transition-duration: 1.5s;
    167     -otransition-duration: 1.5s;
    168     transition-duration: 1.5s;
    169 }
    170 .slide-images.transition-opacity .slide-image {
    171     opacity: 0;
    172      0;
    173     height: 0; /*高宽的设置可以去掉 感觉突兀*/
    174 }
    175 .slide-images.transition-opacity .slide-image.current {
    176     opacity: 1;
    177      550px;
    178     height: 220px;
    179 }
    180 .slide-images.transition-left .slide-image {
    181     left: -550px;
    182     opacity: 0;
    183 }
    184 .slide-images.transition-left .slide-image.current {
    185     left: 0;
    186     opacity: 1;
    187 }
    188 .slide-images.transition-right .slide-image {
    189     right: -550px;
    190     opacity: 0;
    191 }
    192 .slide-images.transition-right .slide-image.current {
    193     right: 0;
    194     opacity: 1;
    195 }
    196 .slide-images.transition-top .slide-image {
    197     opacity: 0;
    198     top: -220px;
    199 }
    200 .slide-images.transition-top .slide-image.current {
    201     opacity: 1;
    202     top: 0;
    203 }
    204 .slide-images.transition-bottom .slide-image {
    205     opacity: 0;
    206     bottom: -220px;
    207 }
    208 .slide-images.transition-bottom .slide-image.current {
    209     opacity: 1;
    210     bottom: 0;
    211 }
    212 .slide-images.transition-cornerzoom .slide-image {
    213     opacity: 0;
    214 }
    215 .slide-images.transition-cornerzoom .slide-image.current {
    216     opacity: 1;
    217 }
    218 .slide-images.transition-cornerzoom .slide-image img {
    219      0;
    220 }
    221 .slide-images.transition-cornerzoom .slide-image.current img {
    222      550px;
    223 }
    224 .slide-images.transition-zoom .slide-image {
    225     opacity: 0;
    226 }
    227 .slide-images.transition-zoom .slide-image.current {
    228     opacity: 1;
    229 }
    230 .slide-images.transition-zoom .slide-image img {
    231     left: -275px;
    232     position: relative;
    233     top: -110px;
    234      1100px;
    235 }
    236 .slide-images.transition-zoom .slide-image.current img {
    237     left: 0;
    238     top: 0;
    239      550px;
    240 }
    241 .slide-images.transition-dezoom .slide-image {
    242     -moz-box-shadow: 2px 2px 8px black;
    243     -webkit-box-shadow: 2px 2px 8px black;
    244     box-shadow: 2px 2px 8px black;
    245     opacity: 0;
    246 }
    247 .slide-images.transition-dezoom .slide-image.current {
    248     opacity: 1;
    249 }
    250 .slide-images.transition-dezoom .slide-image img {
    251     left: 275px;
    252     position: relative;
    253     top: 110px;
    254      0;
    255 }
    256 .slide-images.transition-dezoom .slide-image.current img {
    257     left: 0;
    258     top: 0;
    259      550px;
    260 }
    261 .slide-images.transition-rotate .slide-image {
    262     opacity: 0;
    263 }
    264 .slide-images.transition-rotate .slide-image.current {
    265     opacity: 1;
    266 }
    267 .slide-images.transition-rotate .slide-image img {
    268      550;
    269     height: 220px;
    270     position: relative;
    271     left: -550px;
    272     top: -220px;
    273 }
    274 .slide-images.transition-rotate .slide-image.current img {
    275      550px;
    276     height: 220px;
    277     left: 0;
    278     top: 0;
    279     -moz-transform: rotate(1440deg);
    280     -webkit-transform: rotate(1440deg);
    281     -o-transform: rotate(1440deg);
    282     transform: rotate(1440deg);
    283 }
    284 #options {
    285     margin: 20px auto;
    286     padding: 5px;
    287      550px;
    288 }
    289 </style>
    290 <title>CSS3 transition</title>
    291 </head>
    292 
    293 <body>
    294 <div id="demoSliderContainer">
    295     <ul id="demoSlider" class="slide-images">
    296         <li class="slide-image">
    297             <img src="images/1.jpg" alt="monsters inc" width="550px" height="220px"/>
    298             <span>Monsters Inc</span>
    299         </li>
    300         <li class="slide-image">
    301             <img src="images/2.jpg" alt="nemo" width="550px" height="220px"/>
    302             <span>Nemo</span>
    303         </li>
    304         <li class="slide-image">
    305             <img src="images/3.jpg" alt="up" width="550px" height="220px"/>
    306             <span>Up</span>
    307         </li>
    308         <li class="slide-image">
    309             <img src="images/4.jpg" alt="walle" width="550px" height="220px"/>
    310             <span>Wall-E</span>
    311         </li>
    312     </ul>
    313     <div class="options">
    314         <a href="javascript:;" class="prevSlide"> Prev </a>
    315         <span class="slide-pager">
    316         <a href="#" class="javascript:;">1</a>
    317         <a href="#" class="javascript:;">2</a>
    318         <a href="#" class="javascript:;">3</a>
    319         <a href="#" class="javascript:;">4</a>
    320         </span>
    321         <a href="javascript:;" class="nextSlide"> Next </a>
    322     </div>
    323 </div>
    324 <div id="options">
    325     <label for="transitionEffect">Transition effect :</label>
    326     <select id="transitionEffect">
    327         <option value="transition-left">left slide</option>
    328         <option value="transition-opacity">opacity fade</option>
    329         <option value="transition-right">right slide</option>
    330         <option value="transition-top">top slide</option>
    331         <option value="transition-bottom">bottom slide</option>
    332         <option value="transition-zoom">zoom</option>
    333         <option value="transition-dezoom">de-zoom</option>
    334         <option value="transition-cornerzoom">corner zoom</option>
    335         <option value="transition-rotate">rotate</option>
    336     </select>
    337 </div>
    338 </body>
    339 </html>

    效果示意图:

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

    转载,出处:http://www.w3cplus.com/content/css3-transition#

  • 相关阅读:
    Servlet文件上传下载
    通过jquery将多选框变单选框
    Java 浮点数精度控制
    JS实现点击table中任意元素选中
    SpringMVC-时间类型转换
    SpringMVC--提交表单
    路径 专题
    防盗链
    Request
    RequestResponse简介
  • 原文地址:https://www.cnblogs.com/vincent_ds/p/2646947.html
Copyright © 2020-2023  润新知