CSS3新增特性详解(二)
上篇博文主要介绍了CSS3新增特性中的静态特性,比如新的选择器、多背景图、阴影、渐变等。本文主要介绍CSS3中新增的动态特性,如过度、动画、变形等。
transitian:
-webkit-transition:all 0.5s linear 0.3s;
过度效果,习惯上也叫做渐变。只不过这个渐变是指为动态效果加上一个可视的过程,要与前文中颜色的渐变区分开。
这里还是别忘了在上文中提到的前缀问题,示例中为了节省时间所以只在加了测试用浏览器的前缀。
transition:共四个参数:
1.渐变属性,包括none:停止渐变,all:默认值,元素产生任何属性值变化时都执行渐变效果,通常情况下都用all, indent:指定元素的某一属性值;
2.渐变过程的持续时间,默认值为0;
3.变化的速率,ease:逐渐变慢,linear:匀速,ease-in:加速,ease-out:减速,ease-in-out:先加速后减速,cubic-bezier:自定义;
每个属性都可以设置其具体的贝塞尔曲线值,不过一般情况下用linear匀速就足够了,太另类显得非主流。
4.变化的延迟时间。
之前在讲CSS伪类的那篇文章中已经贴过渐变示例的GIF了。
先写一段代码如下:
div{
width: 100px;
height: 100px;
background-color: red;
}
div:hover{
background-color: blue;
}
效果:

加入渐变:
div{
width: 100px;
height: 100px;
background-color: red;
-webkit-transition:all 0.5s linear 0.3s;
}
div:hover{
background-color: blue;
}
效果:

这里要注意的是transition不仅可以对颜色的改变产生过度效果,也可以对尺寸、位置等等的属性均带来过度效果。

keyframes:
CSS3自带的动画特性,可以不借助JS来完成一些简单的动画效果。但是这里不得不说的是,keyframes的用处并不多,稍微复杂一点的动画用JS搭配CSS3的过度效果总是最理想的。
@-webkit-keyframes divMove{
from{
top:;
left:;
}
to{
top:200px;
left: 200px;
}
}
div{
width: 100px;
height: 100px;
-webkit-border-radius: 50px;
position: absolute;
background-color: forestgreen;
-webkit-animation:divMove 2s infinite linear;
}
首先创建动画规则,最开头用@符号,后接浏览器前缀,后接keyframes,之后是自己定的动画名称。from表示起始状态,to表示结束状态,大括号内写CSS样式。
定义完动画规则后,在你想要加入该动画的元素上添加animation。共有4个参数:1.自定义的动画名称 2.动画完成所用时间 3.infinite表示循环播放动画 4.变化速率,同transition。
效果:

定义动画规则时也可以这样写:
0%{
background-color: red;
}
25%{
background-color: blue;
}
50%{
background-color: green;
}
75%{
background-color: yellow;
}
100%{
background-color: #8a2be2;
}
这样写法是将动画过程按想要的时间百分比细分,上例中from对应0%,to对应100%。
总之CSS3中的动画特性由于其局限性较大,在实际中运用并不多。
transform:
变形,它包括五种变换方式:

div{
-webkit-transform:rotate(30deg);
}
其中rotate后的括号里填旋转的度数,单位:角度(deg)。若值为正则顺时针旋转,为负则逆时针旋转。
效果:

这里还要提一点就是transform-origin(X,Y),它是用来定义元素基点,也就是元素变换的基准点,这旋转这个例子中也就是说绕着哪个点旋转。
X,Y可以是具体的值,也可以是百分比,也可以是top center bottom left right这样的参数。在未设置的情况下,默认为元素的几何中心。
translate移动:
黑框中有一绿色方块

移动:
#demo{
width: 100px;
height:100px;
background-color: seagreen;
-webkit-transform:translate(150px,0)
}
效果:

还可以写成translateX(x) translateY(y),表示只横向或纵向移动,括号里仅有一个参数。
scale缩放:
写法:scale(X,Y),其中X,Y表示横、纵向缩放倍数,基值为1。若大于1表示放大,小于1表示缩小,如scale(0.8,2.5)表示横向缩小到0.8倍,纵向放大到2.5倍。
与translate类似,缩放也可以单方向:scaleX(x)&scaleY(y)。
skew扭曲:
写法:skew(X,Y),X表示水平方向扭曲角度,Y表示垂直方向扭曲角度。如:skew(30deg,10deg)。同上,单方向扭曲:skewX(x)&skewY(y)。
#demo{
width: 100px;
height:100px;
background-color: seagreen;
-webkit-transform:skewX(30deg);
}

这种东西怎么能用在网页上呢?看的博主心理都扭曲了。
感谢您的浏览,希望能对您有所帮助。
CSS3新增特性详解(二)的更多相关文章
- CSS3新增特性详解(一)
注:由于CSS3的新特性较多,所以分两篇博文来说明.第一篇主要包括新的选择器.文字及块阴影.多背景图.颜色渐变.圆角等.第二篇主要细说CSS3的各种动画效果,如:旋转.移动.缩放等,还包括图标字体的应 ...
- C#各个版本中的新增特性详解
序言 自从2000年初期发布以来,c#编程语言不断的得到改进,使我们能够更加清晰的编写代码,也更加容易维护我们的代码,增强的功能已经从1.0搞到啦7.0甚至7.1,每一次改过都伴随着.NET Fram ...
- C#各个版本中的新增特性详解【转】
序言 自从2000年初期发布以来,c#编程语言不断的得到改进,使我们能够更加清晰的编写代码,也更加容易维护我们的代码,增强的功能已经从1.0搞到啦7.0甚至7.1,每一次改过都伴随着.NET Fram ...
- 【PHP系列】PHP 7.0新增特性详解
开始介绍PHP7.0新特性,具体的可以参照官网的介绍,我来挑一些给大家详细讲解下 http://php.net/manual/en/migration70.new-features.php 1. ?? ...
- MySQL 8.0新增特性详解【华为云技术分享】
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/devcloud/article/detai ...
- PHP 7.0新增特性详解
https://www.cnblogs.com/riverdubu/archive/2017/03/22/6434705.html 开始介绍PHP7.0新特性,具体的可以参照官网的介绍,我来挑一些给大 ...
- CSS3新特性详解
本文讲解CSS3相关实用知识点 CSS3相关实用知识点目录 边框设置 颜色设置 背景设置 渐变使用 超出文本设置 阴影设置 CSS3变换设置 过渡设置 动画设置 多列布局 BoxSizing设置 弹性 ...
- Android群英传笔记——第十二章:Android5.X 新特性详解,Material Design UI的新体验
Android群英传笔记--第十二章:Android5.X 新特性详解,Material Design UI的新体验 第十一章为什么不写,因为我很早之前就已经写过了,有需要的可以去看 Android高 ...
- 《Android群英传》读书笔记 (5) 第十一章 搭建云端服务器 + 第十二章 Android 5.X新特性详解 + 第十三章 Android实例提高
第十一章 搭建云端服务器 该章主要介绍了移动后端服务的概念以及Bmob的使用,比较简单,所以略过不总结. 第十三章 Android实例提高 该章主要介绍了拼图游戏和2048的小项目实例,主要是代码,所 ...
随机推荐
- vmware查看HBA卡、网卡驱动、firmware版本信息
在 ESXi 5.x 中,swfw.sh 命令随 vm-support 支持包收集工具一起提供.swfw.sh 命令可用来识别连接到主机的硬件的固件和驱动程序版本.要运行此命令,请使用该路径: # / ...
- November 18th 2016 Week 47th Friday
Get a livelihood and then practise virtue. 先谋生,而后修身. If you can't earn a life, all the things you ha ...
- fun()()() ---- 函数的嵌套
结果--"嘿嘿"
- Deadline下:写论文的总结
终于赶在了11月底截止的时刻提交上了导航年会的论文.三天加上两个半晚上差不多干完了80%的活,无论是否能够被录,这次的写作收获很大. 认识到了: 1. 读文献时,一定要带着问题,如果是我来做,我会怎么 ...
- BZOJ 2424 订货 最小费用流
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2424 题目大意: 某公司估计市场在第i个月对某产品的需求量为Ui,已知在第i月该产品的 ...
- POJ3977 Subset
嘟嘟嘟 这个数据范围显然是折半搜索. 把序列分成两半,枚举前一半的子集,存下来.然后再枚举后一半的子集,二分查找. 细节: 1.最优解可能只在一半的子集里,所以枚举的时候也要更新答案. 2.对于当前结 ...
- 列表中不限制宽度,hover时,字体font-weight:bold,防止抖动
项目一个小问题困扰了很久,在一个没有限制宽度的列表容器中,如果给hover时,给字体➕'font-wieght:bold'容器就会变宽,然后移动的下一个容器,就会出现抖动,这样很是影响用户体验,于是在 ...
- c++——默认参数、函数占位参数
2 默认参数 /*1 C++中可以在函数声明时为参数提供一个默认值, 当函数调用时没有指定这个参数的值,编译器会自动用默认值代替 */ void myPrint(int x = 3) { printf ...
- 基于Verilog的偶数、奇数、半整数分频以及任意分频器设计
在FPGA的学习过程中,最简单最基本的实验应该就是分频器了.由于FPGA的晶振频率都是固定值,只能产生固定频率的时序信号,但是实际工程中我们需要各种各样不同频率的信号,这时候就需要对晶振产生的频率进行 ...
- MySQL(三)架构
和其他数据库相比,MySQL有点与众不同,他的架构可以在多种不同场景中应用并发挥好的作用,但同时也会带来一点选择上的困难.MySQL并不完美,却足够灵活,能够适应高要求的环境.为了充分发挥MySQL的 ...