css3 transition

W3C标准中对css3transition这是样描述的:“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(秒)或者ms(毫秒),可以作用于所有元素,包括: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:(该值允许你去自定义一个时间曲线), 特定的cubic-bezier曲线。 (x1, y1, x2, y2)四个值特定于曲线上点P1和点P2。所有值需在[0, 1]区域内,否则无效。
其是cubic-bezier为通过贝赛尔曲线来计算“转换”过程中的属性值,如下曲线所示,通过改变P1(x1, y1)和P2(x2, y2)的坐标可以改变整个过程的Output Percentage。初始默认值为default.


其他几个属性的示意图:

四、transition-delay:
语法:
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。如:
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:
<a id="timings-demo-btn">click</a> <div id="timings-demo"> <div id="ease" class="demo-box">Ease</div> <div id="ease-in" class="demo-box">Ease-in</div> <div id="ease-out" class="demo-box">Ease-out</div> <div id="ease-in-out" class="demo-box">Ease-in-out</div> <div id="linear" class="demo-box">Linear</div> <div id="cubic-bezier" class="demo-box">Cubic-bezier</div> </div>

CSS Code:

timings-demo { border: 1px solid #ccc; padding: 10px; height: 400px; width: 400px; } .demo-box { width: 100px; height: 50px; text-align: center; line-height: 50px; text-align: center; color: #fff; background: #96c; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; -moz-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5); -webkit-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5); box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5); margin-bottom: 10px; } //ease效果: #ease { -moz-transition: all 5s ease 0.3s; -webkit-transition: all 5s ease 0.3s; -o-transition: all 5s ease 0.3s; transition: all 5s ease 0.3s; background: #f36; } //ease-in效果: #ease-in { -moz-transition: all 3s ease-in 0.5s; -webkit-transition: all 3s ease-in 0.5s; -o-transition: all 3s ease-in 0.5s; transition: all 3s ease-in 0.5s; background: #369; } //ease-out效果: #ease-out { -moz-transition: all 5s ease-out 0s; -webkit-transition: all 5s ease-out 0s; -o-transition: all 5s ease-out 0s; transition: all 5s ease-out 0s; background: #636; } //ease-in-out效果: #ease-in-out { -moz-transition: all 1s ease-in-out 2s; -webkit-transition: all 1s ease-in-out 2s; -o-transition: all 1s ease-in-out 2s; transition: all 1s ease-in-out 2s; background: #3e6; } //linear效果: #linear { -moz-transition: all 6s linear 0s; -webkit-transition: all 6s linear 0s; -o-transition: all 6s linear 0s; transition: all 6s linear 0s; background: #999; } //cubic-bezier效果: #cubic-bezier { -moz-transition: all 4s cubic-bezier 1s; -webkit-transition: all 4s cubic-bezier 1s; -o-transition: all 4s cubic-bezier 1s; transition: all 4s cubic-bezier 1s; background: #6d6; } //hover状态下或单击click按钮后demo-box产生属性变化 #timings-demo.timings-demo-hover .demo-box, #timings-demo:hover .demo-box { -moz-transform: rotate(360deg) scale(1.2); -webkit-transform: rotate(360deg) scale(1.2); -o-transform: rotate(360deg) scale(1.2); transform: rotate(360deg) scale(1.2); background: #369; border: 1px solid rgba(255,230,255,08); -moz-border-radius: 25px; -webkit-border-radius: 25px; border-radius: 25px; margin-left: 280px; height: 30px; line-height: 30px; margin-bottom: 15px; }

使用单击事件给dimings-demo加上一个timings-demo-hover的class名,使用demo-bxo产生属性变化
$(document).ready(function(){ $("#timings-demo-btn").toggle( function(){ $(this).next("div#timings-demo").addClass("timings-demo-hover"); },function(){ $(this).next("div#timings-demo").removeClass("timings-demo-hover"); }); });

我们来看看其效果图

未改变属性效果
正在变换中
执行完动画后的最终效果
上图是鼠标移动到#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:
<div id="demoSliderContainer"> <ul id="demoSlider" class="slide-images"> <li class="slide-image">
<span>Monsters Inc</span> </li> <li class="slide-image">
<span>Nemo</span> </li> <li class="slide-image">
<span>Up</span> </li> <li class="slide-image">
<span>Wall-E</span> </li> </ul> <div class="options"> <a href="javascript:;" class="prevSlide">Prev</a> <span class="slide-pager"> <a href="" class="javascript:;">1</a> <a href="" class="javascript:;">2</a> <a href="" class="javascript:;">3</a> <a href="" class="javascript:;">4</a> </span> <a href="javascript:;" class="nextSlide">Next</a> </div> </div> <div id="options"> <label for="transitionEffect">Transition effect :</label> <select id="transitionEffect"> <option value="transition-opacity">opacity fade</option> <option value="transition-left">left slide</option> <option value="transition-right">right slide</option> <option value="transition-top">top slide</option> <option value="transition-bottom">bottom slide</option> <option value="transition-zoom">zoom</option> <option value="transition-dezoom">de-zoom</option> <option value="transition-cornerzoom">corner zoom</option> <option value="transition-rotate">rotate</option> </select> </div>

CSS Code:

demoSliderContainer { background: #000; -moz-box-shadow: 1px 1px 5px #000; -webkit-box-shadow: 1px 1px 5px #000; box-shadow: 1px 1px 5px #000; padding: 0; overflow: auto; margin: 10px auto; width: 560px;} #demoSlider { border: 1px solid #000; border-width: 5px 5px 0; height: 220px; margin: 0 auto; width: 550px; overflow: hidden; position: relative;} .slide-images .slide-image { position: absolute;} .slide-images .slide-image img { z-index: 2;} .slide-images .slide-image span { background: rgba(0,0,0,0.3); -moz-border-radius: 5px 0 0 0; -webkit-border-radius: 5px 0 0 0; border-radius: 5px 0 0 0; bottom: 4px; color: rgba(255,255,255,0.8); font-size: 14px; font-weight: bold; padding: 5px 10px; position: absolute; right: 0; z-index: 3;}.slide-images .slide-image.current img { z-index: 12;} .slide-images .slide-image.current span { z-index: 13;} #demoSliderContainer .options { padding: 3px 10px; text-align: center;}#demoSliderContainer .options a { color: #91BECC; font-family: Georgia,Serif; font-size: 12px; font-weight: bold; text-decoration: none;}#demoSliderContainer .options a:hover { color: #D3E5EB;}#demoSliderContainer .slide-pager a { -moz-transition-duration: 0.5s; -webkit-transition-duration: 0.5s; -o-transition-duration: 0.5s; transition-duration: 0.5s;}#demoSliderContainer .slide-pager a.current { background-color: #91BECC; border-radius: 5px 5px 5px 5px; color: black; padding: 0 4px;}#demoSliderContainer .options .prevSlide { float: left;}#demoSliderContainer .options .nextSlide { float: right;} /transition effect/.slide-images .slide-image,.slide-images .slide-image img { -moz-transition-duration: 1.5s; -webkit-transition-duration: 1.5s; -otransition-duration: 1.5s; transition-duration: 1.5s; } .slide-images.transition-opacity .slide-image { opacity: 0; width: 0; } .slide-images.transition-opacity .slide-image.current { opacity: 1; width: 550px; } .slide-images.transition-left .slide-image { left: -550px; opacity: 0; } .slide-images.transition-left .slide-image.current { left: 0; opacity: 1; } .slide-images.transition-right .slide-image { right: -550px; opacity: 0; } .slide-images.transition-right .slide-image.current { right: 0; opacity: 1; } .slide-images.transition-top .slide-image { opacity: 0; top: -220px; } .slide-images.transition-top .slide-image.current { opacity: 1; top: 0; } .slide-images.transition-bottom .slide-image { opacity: 0; bottom: -220px; } .slide-images.transition-bottom .slide-image.current { opacity: 1; bottom: 0; } .slide-images.transition-cornerzoom .slide-image { opacity: 0; } .slide-images.transition-cornerzoom .slide-image.current { opacity: 1; } .slide-images.transition-cornerzoom .slide-image img { width: 0; } .slide-images.transition-cornerzoom .slide-image.current img { width: 550px; } .slide-images.transition-zoom .slide-image { opacity: 0; } .slide-images.transition-zoom .slide-image.current { opacity: 1; } .slide-images.transition-zoom .slide-image img { left: -275px; position: relative; top: -110px; width: 1100px; } .slide-images.transition-zoom .slide-image.current img { left: 0; top: 0; width: 550px; } .slide-images.transition-dezoom .slide-image { -moz-box-shadow: 2px 2px 8px black; -webkit-box-shadow: 2px 2px 8px black; box-shadow: 2px 2px 8px black; opacity: 0; } .slide-images.transition-dezoom .slide-image.current { opacity: 1; } .slide-images.transition-dezoom .slide-image img { left: 275px; position: relative; top: 110px; width: 0; } .slide-images.transition-dezoom .slide-image.current img { left: 0; top: 0; width: 550px; } .slide-images.transition-rotate .slide-image { opacity: 0; } .slide-images.transition-rotate .slide-image.current { opacity: 1; } .slide-images.transition-rotate .slide-image img { width: 550; height: 220px; position: relative; left: -550px; top: -220px; } .slide-images.transition-rotate .slide-image.current img { width: 550px; height: 220px; left: 0; top: 0; -moz-transform: rotate(1440deg); -webkit-transform: rotate(1440deg); -o-transform: rotate(1440deg); transform: rotate(1440deg); } #options { margin: 20px auto; padding: 5px; width: 550px; }

jQuery Code:
<script type="text/javascript"> $(document).ready(function(){ $(".slide-images").each(function(){ var slider = $(this); var slides = $(".slide-image",slider); var sliderPages = $(".slide-pager"); //Slide Navigation var currentSlideNum = 0; slides.removeClass("current"); slides.eq(currentSlideNum).addClass("current"); sliderPages.each(function(){ var pages = $("a",this); pages.removeClass("current"); pages.eq(currentSlideNum).addClass("current"); }); var goToSlide = function(slideNum) { slides.eq(currentSlideNum).removeClass("current"); slides.eq(slideNum).addClass("current"); sliderPages.each(function(){ var pages = $("a", this); pages.eq(currentSlideNum).removeClass("current"); pages.eq(slideNum).addClass("current"); }); currentSlideNum = slideNum; }; var nextSlide = function() { var nextSlideNum = currentSlideNum + 1; if(nextSlideNum >= slides.size()) nextSlideNum = 0; goToSlide(nextSlideNum); }; var prevSlide = function() { var prevSlideNum = currentSlideNum - 1; if(prevSlideNum < 0) prevSlideNum = slides.size() - 1; goToSlide(prevSlideNum); }; //transition effects var setTransitionEffect = function(transitionEffect) { slider.attr("class","slide-images "+ transitionEffect); }; $("#transitionEffect").change(function(){ setTransitionEffect($(this).val()); }).change(); //Navigation binding $(".prevSlide").click(prevSlide); $(".nextSlide").click(nextSlide); $(".slide-pager a").each(function(i){ if(i >= slides.size()) return false; $(this).click(function(){ goToSlide(i); }); }); //Auto next slide var lastHumanNav = 0; $(".prevSlide, .nextSlide, .slide-pager a").click(function(){ lastHumanNav = new Date().getTime(); }); setInterval(function(){ var now = new Date().getTime(); if(now - lastHumanNav > 5000) nextSlide(); },5000); }); }); </script>

记得在你的本地页面头部加上jQuery的版本库文件。
效果示意图:


DEMO二思路来自于Greweb.fr并在其基础上增加了right silde,bottom silde,rotate三种效果,如果你感兴趣的话可以在这个基础上增加更多的slideshow效果,比如利用transform的scale,skew等制作出更出色的效果。
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。原文: https://www.w3cplus.com/content/css3-transition © w3cplus.com

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 上一篇介绍了CSS3里transform变形属性,本篇介绍另一个人气动画属性transition。transiti...
    张歆琳阅读 24,994评论 1 31
  • CSS3有transition、transform这些属性,它们是用来移动元素过渡元素之类的。 transform...
    sakatayui酱阅读 627评论 0 0
  • Transition and animations 贝塞尔曲线在线工具(需翻墙) 贝塞尔曲线在线工具(无需翻墙)...
    ilaoke阅读 934评论 1 5
  • 一、首先学习的是transition属性(zoom不支持transition,适用于具体数值的属性值变化或者背景图...
    Farewell_V587阅读 1,210评论 1 3
  • 今日静心方向:星币1 从云里伸出一只手,稳稳的拖着一枚黄灿灿的星币。特别喜欢这个星币,感觉这个星币很大很厚实,还水...
    塔罗师默默阅读 199评论 0 0