一、过渡

什么是过渡?

过渡是指:某元素的css属性值在一段时间内,平滑过渡到另外一个值,过渡主要观察的是过程和结果。

设置能够过渡的属性:

支持过渡的样式属性,颜色的属性,取值为数值,transform,渐变,visibility, 阴影

指定本次过渡生效的属性:

transition-poperty:上面的css属性/all

指定过渡的时长

transition-duration:过渡时长/s/ms

指定过渡时间曲线函数

transition-timing-function:

1.ease 默认值,慢-->快-->慢  慢速开始,快速变快,慢速结束

2.linear 匀速

3.ease-in 慢--->快  慢速开始,快速结束

4.ease-out 快速开始,慢速结束

5.ease-in-out 慢速开始,先加速再减速,慢速结束

指定延迟执行过渡的时间

transition-delay:   s/ms

过渡属性的编写位置

1.将过渡放在元素声明的样式中(元素自己的样式里)过渡效果有去有回。

2.将过渡放在元素的触发操作中(hover),过渡效果有去无回。

过渡的简写:

transition:property duration timing-function delay;

最少的方式:transition:duration;

二、动画

什么是动画?

使元素从一种样式,改变到另外一种,再改变到其他样式......

相当于将很多个过渡效果放到一起使用。

关键帧:

1.动画的执行时间点

2.该时间点上的样式

动画的实现步骤:

1.声明动画及动画关键帧

@keyframes  动画名称{

//定义关键帧

0%{ 动画开始的样式 }

........

100%{动画结束时的样式}

}

2.调用动画

animation-name:动画名称;

animation-duration:动画播放一个周期的时间;

3.动画的其他属性

animation-delay

4.动画的速度时间曲线函数

animation-timing-function

ease/linear/ease-in/ease-out/ease-in-out

5.animation-iteration-count

指定动画的播放次数

取值,具体的数字/infinite无限次

6.animation-direction:

动画的播放方向

取值  normal       正常            0%-100%

reverse     逆向播放    100%-0%

alternate   轮流播放

奇数次正向播放

偶数次逆向播放

7.简写方式:

animation:name duration timing-function delay iteration-count direction;

8.animation-fill-mode

指定动画播放前后的显示状态

1.none  默认值

2.forwards 动画完成后,保持在最后一个关键帧上

3.backwards(需要有delay)动画开始之前,保持在第一个关键帧上

4.both,同时设置forwards和backwards

动画的兼容性:

如果要兼容低版本的浏览器,需要在声明动画的时候加前缀

@keyframes 动画名称{}

@-webkit-keyframes

@-moz-keyframes

@-o-keyframes

三.CSS优化

目的:减少服务器压力,提升用户体验。

1.优化原则

尽量减少HTTP请求的个数。

页面顶部引入css样式

将css和js放到外部独立的文件夹中

2.CSS代码优化

缩小样式文件

减少样式的重写

避免出现空的src和href

选择更优的样式属性值(能使用复合,简写的写法,就不要单独定义)

代码压缩

最新文章

  1. ORACLE 11gR2 DG(Physical Standby)日常维护01
  2. 用C#,SQL Server编写的音乐播放软件
  3. 腾讯OAuth授权联合登录
  4. RCP:解决Navigator快捷键不生效的问题
  5. Activating Google Cloud Storage
  6. Android 向系统添加一个联系人信息contact
  7. scheme递归
  8. VSTO不能创建OFFICE 文档项目的原因
  9. UEP-保存
  10. .net(C#)在Access数据库中执行sql脚本
  11. 文本在div中始终垂直居中
  12. AIOps背景/所应具备技术能力分析(上)
  13. jQuery File Upload 图片上传解决方案兼容IE6+
  14. js小方法积累,将一个数组按照n个一份,分成若干数组
  15. 牛客OI周赛7-普及组 解题报告
  16. 按顺序动态加载js, 可控版本, 有回调
  17. test20180828
  18. 比较undefined和“undefined”
  19. java中重要的多线程工具类
  20. 初学Hadoop:利用VMWare+CentOS7搭建Hadoop集群

热门文章

  1. Springboot2.x + ShardingSphere 实现分库分表
  2. Web安全 --Wfuzz 使用大全
  3. margin与padding的区别与用法—以及出现bug的解决方法
  4. 存储物理页属性的PFN数据库
  5. 利用phar实行php反序列化命令执行漏洞复现
  6. java架构之路-(Redis专题)SpringBoot连接Redis超简单
  7. 8.Nginx基本概述
  8. SpringBoot是如何动起来的?
  9. 学习Spring的思考框架
  10. jQuery插件图片懒加载lazyload