




已阅读5页,还剩24页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
今天我们接着一起来看CSS3动画属性中的一个属性Transition。W3C标准中对css3的transition这是样描述的:“css的transition允许css的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变CSS的属性值。”下面我们同样从其最语法和属性值开始一步一步来学习transition的具体使用语法:1transition : | | | , | | | *transition 主要包含四个属性值:执行变换的属性:transition-property,变换延续的时间:transition-duration,在延续时间 段,变换的速率变化transition-timing-function,变换延迟时间transition-delay。下面分别来看这四个属性值一、transition-property:语法:1transition-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 Transform7、rectangle:通过x, y, width 和 height(转为数值)变换,如:crop8、visibility: 离散步骤,在0到1数字范围之内,0表示“隐藏”,1表示完全“显示”,如:visibility9、shadow: 作用于color, x, y 和 blur(模糊)属性,如:text-shadow10、gradient: 通过每次停止时的位置和颜色进行变化。它们必须有相同的类型(放射状的或是线性的)和相同的停止数值以便执行动画,如:background-image11、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:语法:1transition-duration : , *transition-duration是用来指定元素 转换过程的持续时间,取值:为数值,单位为s(秒),可以作用于所有元素,包括:before和:after伪元素。其默认值是0,也就是变换时是即时的。三、transition-timing-function:语法:1transition-timing-function : ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(, , , ) , ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(, , , )*取值: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:语法:1transition-delay : , *transition- delay是用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行transition效果,其取值: 为数值,单位为s(秒),其使用和transition-duration极其相似,也可以作用于所有元素,包括:before和:after伪元素。 默认大小是0,也就是变换立即执行,没有延迟。有时我们不只改变一个css效果的属性,而是想改变两个或者多个css属性的 transition效果,那么我们只要把几个transition的声明串在一起,用逗号(“,”)隔开,然后各自可以有各自不同的延续时间和其时间的 速率变换方式。但需要值得注意的一点:transition-delay与transition-duration的值都是时间,所以要区分它们在连写中 的位置,一般浏览器会根据先后顺序决定,第一个可以解析为时间的怭值为transition-duration第二个为transition- delay。如:123456a -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属性值来操作,此时他们共享同样的延续时间以及速率变换方式,如:123456a -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: 如下图所示:相对应的一个示例代码:123456p -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 : | | | , | | | * /Webkit内核 -webkit-transition : | | | , | | | * /Opera -o-transition : | | | , | | | * /W3C 标准 transition : | | | , | | | * 通过上面,我想大家对CSS3的Transition属性的使用有一定的概念存在了,下面为了加强大家在这方面的使用,我们一起来看下面的DEMO。我们通过实践来巩固前面的理论知识,也通过实践来加强transition的记忆。DEMO一:DEMO 一我们主要是在一个div中放置了几个小块,分别是对应了transition-timing-function中的几种类型,我们在div的hover 状态下,改变其部分属性,从而达到一种动画效果。我们也可以使用jq来点击一个按钮,触发这个div(说简单点就是通过按钮的点击事件给这个div加上一 个class,让其子元素都触发相对应的transition动画效果),为了让大家能更好的学习和理解,我把相应的代码贴在这里,感兴趣的朋友就跟着做 一下吧,也可以直接把代码复制到你本地页面运行查看效果。Html Code:123456789clickEaseEase-inEase-outEase-in-outLinearCubic-bezierCSS Code:12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788#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产生属性变化12345678$(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:1234567891011121314151617181920212223242526272829303132333435363738394041424344Monsters IncNemoUpWall-EPrev1234NextTransition effect :opacity fadeleft slideright slidetop slidebottom slidezoomde-zoomcorner zoomrotateCSS Code:123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227#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 bla
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 1.3 信息及其特征 教学设计 2023-2024学年粤教版(2019)高中信息技术 必修1
- 福建省泰宁一中2016年高一化学《硝酸的性质》教学设计
- 探究活动课二 古老文化与现代文明教学设计-2025-2026学年高中历史人教版2007选修1历史上重大改革回眸-人教版2007
- 线下清明祭英烈活动方案
- 端午答谢活动方案
- 腌腊发酵制品加工工操作考核试卷及答案
- 光缆护套工数字化技能考核试卷及答案
- 手持小型动力工具制作工安全规范考核试卷及答案
- 口腔护理液制造工适应性考核试卷及答案
- 光伏晶硅组件制造工岗前考核试卷及答案
- 公证与婚姻家庭事务
- 产业园区运营模式(课件)
- 信息可视化设计全套教学课件
- 口腔粘膜病课件
- 关于PedSQL-4.0儿童生存质量测定量表调查
- 年产62万吨甲醇制烯烃(MTO)项目初步设计说明书
- 联通创新人才认证(解决方案)考试题库(附答案)
- ICU患者的早期活动
- 出纳课件 转账支票pptx
- TSZUAVIA 009.11-2019 多旋翼无人机系统实验室环境试验方法 第11部分:淋雨试验
- ps6000自动化系统用户操作及问题处理培训
评论
0/150
提交评论