• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 浅谈CSS过渡、动画和变换

浅谈CSS过渡、动画和变换

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS,过渡,动画,变换等相关知识,佚名 希望在学习及工作中可以帮助到您

1. 使用过渡

过渡效果一般是由浏览器直接改变元素的CSS属性实现的。例如,如果使用:hover选择器,一旦用户将鼠标悬停在元素之上,浏览器就会应用跟选择器关联的属性。

当用户将鼠标悬停在span元素上的时候,浏览器就会响应,直接应用新的属性。变化如下图所示:

CCS过渡属性允许控制应用新属性值的速度。比如可以选择逐渐改变示例中span元素的外观,让鼠标移到单词banana上的效果更和谐。

 

transition-delay 和 transition-duration 属性指定为CSS时间,是一个数字,单位为ms(毫秒)或者s(秒)。

transition简写属性的格式如下: 

  1. transition: <transition-property> <transition-duration> <transition-timing-function> <transition-delay>  

修改前面示例的CSS代码如下:

  1. p { padding: 5px; border: medium double black; background-color: lightgray; font-family: sans-serif;}   
  2. #banana { font-size: large; border: medium solid green;}   
  3. #banana:hover {   
  4.     font-size: x-large; border: medium solid white; background-color: #1fa6e6; color: white; padding: 4px;   
  5.     transition-delay: 100ms;   
  6.     transition-property: background-color,color,padding,font-size,border;   
  7.     transition-duration: 500ms;   
  8. }  

在这个例子中,为样式添加了过渡,是通过#banana:hover 选择器应用的。过渡会在用户将鼠标悬停在span元素上100ms之后开始,持续时间为500ms,过渡应用到 background-color、color、padding、font-size和border属性。下面的效果图展示了这个过渡的渐进过程:

注意这个示例中指定多个属性的方式。过渡属性的值用逗号隔开,这样过渡效果才会同时出现。可以为延迟时间和持续时间指定多个值,它代表的意思是不同的属性在不同的时间点开始过渡,且持续时间也不同。

1.1 创建反向过渡

过渡只有在应用与其关联的样式时才会生效。示例样式中使用了:hover 选择器,这意味着只有用户将鼠标悬停在span元素上才会应用样式。用户一旦将鼠标从span元素上已开,只剩下#banana样式,默认情况下,元素的外观会立刻回到初始状态。

因为这个原因,大多数过渡成对出现:暂时状态的过渡和方向相反的反向过渡。修改前面示例的CCS代码,从而展示如何通过应用另一种过渡样式平滑地返回初始样式。

  1. p { padding: 5px; border: medium double black; background-color: lightgray; font-family: sans-serif;}   
  2. #banana {   
  3.     font-size: large; border: medium solid green;   
  4.     transition-delay: 100ms;   
  5.     transition-duration: 500ms;}   
  6. #banana:hover {   
  7.     font-size: x-large; border: medium solid white; background-color: #1fa6e6; color: white; padding: 4px;   
  8.     transition-delay: 100ms;   
  9.     transition-property: background-color,color,padding,font-size,border;   
  10.     transition-duration: 500ms;   
  11. }  

1.2 选择中间值的计算方式

使用过渡时,浏览器需要为每个属性计算初始值和最终值之间的中间值。使用transition-timing-function 属性指定计算中间值的方式,表示为四个点控制的三次贝塞尔曲线。有五种预设曲线可以选择,由下面的值表示:

* ease(默认值)

* linear

* ease-in

* ease-out

* ease-in-out

从下图可以看到这五种曲线,它们展示了中间值随着时间的推移变为最终值的速率。

搞清楚这些值最简单的办法就是在自己的HTML文档中试验。还有另外一个值 cubic-bezier,可用来指定自定义曲线。

修改前面示例的CSS样式如下,展示 transition-timing-function 属性的应用:

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06div中子div在firefox ie 水平居中对齐
  • 2017-08-06网站导航菜单的分割线和水平居中
  • 2017-08-06ie css margin auto 不居中解决方案
  • 2017-08-06关于css兼容性问题及一些常见问题汇总
  • 2017-08-06小议Data URI scheme及其在CSS中的相关使用
  • 2017-08-06css中padding和margin的异同点介绍
  • 2017-08-06浏览器对于含小数值px(像素)解析的差异及小数值如何解决兼容性问题
  • 2017-08-06CSS美化下拉框select在火狐和谷歌浏览器下已测试
  • 2017-08-06移动Web—CSS为Retina屏幕替换更高质量的图片
  • 2017-08-06CSS隐藏页面文字的几种方式总结

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • firefox不显示border通过清除float便可解决
    • 使用css3实现的tab选项卡代码分享
    • CSS的font-size属性及其em值的使用
    • css控制列表与导航的制作(水平导航条、垂直翻转的列表、垂直导航栏、内联列表、列表样
    • 不用table而实现等分DIV的方法
    • CSS3实例分享--超炫checkbox复选框和radio单选框
    • div css 鼠标悬停在div层上时,div背景色改变
    • 浅谈CSS3动画的回调处理
    • 基于Jquery和Css3代码制作可以缩放的搜索框
    • CSS3旋转——彩色扇子兼容firefox浏览器

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有