经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » CSS » 查看文章
CSS 小结笔记之变形、过渡与动画的示例_CSS教程_CSS
来源:jb51  时间:2018/9/25 19:06:56  对本文有异议

1、过渡 transition 

过渡属性用法: transition :ransition-property  transition-duration  transition-timing-function   transition-delay 

可以一起指定也可以分别单独指定

transition-property: 是要过渡的属性(如width,height),all是所有都改变。

transition-duration:花费的时间,单位为s或ms

transition-timing-function:是指定动画类型(运动区曲线),运动曲线有以下几种

ease=>逐渐慢下来(默认值) linear=>匀速 ease-in=>加速 ease-out=>减速 ease-in-out=>先加速在减速 

transition-delay 延迟时间,单位为s或ms

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 100px;
  12. height: 200px;
  13. background-color: aqua;
  14. transition: width 2s ease-in-out 0.5s;
  15. }
  16. div:hover {
  17. width: 500px;
  18. }
  19. </style>
  20. </head>
  21.  
  22. <body>
  23. <div></div>
  24. </body>
  25.  
  26. </html>

结果如下,当鼠标上上去后变化不再是瞬间完成,而是过渡完成。

2、变形 transform

 (1)、2D变形

(a)移动 translate(x,y)

移动可以指定像素值也可以指定百分比, 注意:指定百分比是自身大小的百分比,因此可以用于设置盒子定位时的居中对齐(在设置left:50%后再移动自身的-50%即可)。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 100px;
  12. height: 100px;
  13. background-color: aqua;
  14. transition: all 2s;
  15. }
  16. div:active {
  17. transform: translate(200px, 200px);
  18. }
  19. </style>
  20. </head>
  21.  
  22. <body>
  23. <div></div>
  24. </body>
  25.  
  26. </html>

点击之后盒子进行了移动。用于让定位的盒子居中的代码入下

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. .fa {
  11. width: 300px;
  12. height: 300px;
  13. background-color: aqua;
  14. transition: all 0.5s;
  15. position: relative;
  16. }
  17. .son {
  18. background-color: red;
  19. position: absolute;
  20. left: 50%;
  21. top: 50%;
  22. width: 100px;
  23. height: 100px;
  24. transform: translate(-50%, -50%);
  25. }
  26.  
  27. </style>
  28. </head>
  29.  
  30. <body>
  31. <div class="fa">
  32. <div class="son"></div>
  33. </div>
  34.  
  35. </body>
  36.  
  37. </html>

结果为

(b)缩放 scale(x,y)

x,y设置大于1 是放大,小于1 是缩小。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 100px;
  12. height: 100px;
  13. background-color: aqua;
  14. margin: 200px auto;
  15. transition: all 2s;
  16. }
  17. div:hover {
  18. transform: scale(0.5, 2);
  19. }
  20. </style>
  21. </head>
  22.  
  23. <body>
  24. <div>
  25.  
  26. </div>
  27. </body>
  28.  
  29. </html>

(c)旋转 rotate(x deg)

x指定度数值,正数是顺时针旋转,负数是逆时针旋转。

旋转可以使用 transform-origin  指定旋转中心点,transform-origin 给left top right bottom 也可以指定具体的像素值。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 200px;
  12. height: 100px;
  13. background-color: aqua;
  14. margin: 200px auto;
  15. transition: all 2s;
  16. transform-origin: bottom left;
  17. }
  18. div:hover {
  19. transform: rotate(120deg);
  20. }
  21. </style>
  22. </head>
  23.  
  24. <body>
  25. <div></div>
  26. </body>
  27.  
  28. </html>

(d)倾斜 skew(x deg ,y deg)

x,y分别指定倾斜在x,y方向上的角度,可以为负数。y值不写默认为0。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 100px;
  12. height: 100px;
  13. background-color: aqua;
  14. border: 1px solid red;
  15. transition: all 1s;
  16. margin: 200px auto;
  17. }
  18. div:hover {
  19. transform: skew(30deg, 20deg);
  20. }
  21. </style>
  22. </head>
  23.  
  24. <body>
  25. <div></div>
  26. </body>
  27.  
  28. </html>

(2)3D变形

(a)旋转(rotateX,rotateY,rotateZ)

3D旋转与2D类似,只不过一个是基于二位坐标一个是基于三维坐标。三个值可以同时指定也可以单独指定。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 200px;
  12. height: 100px;
  13. background-color: aqua;
  14. margin: 200px auto;
  15. transition: all 2s;
  16. transform-origin: bottom left;
  17. }
  18. div:hover {
  19. transform: rotateX(120deg);
  20. /* transform: rotateY(120deg); */
  21. /* transform: rotateZ(120deg); */
  22. }
  23. </style>
  24. </head>
  25.  
  26. <body>
  27. <div></div>
  28. </body>
  29.  
  30. </html>

(b)移动(translateX,translateY,translateZ)

3D移动对于xy方向上的移动与2d移动一致。只有z方向上的移动不一样。Z方向上的移动在现实生活中是距离变远,距离变近。因此在网页中显示结果是变近则变大,变远则变小。

要使Z放线上移动生效首先要设置perspective(眼睛距离屏幕的距离);

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. body {
  11. perspective: 1000px;
  12. /* 数值越小说明眼睛离的越近 */
  13. }
  14. div {
  15. width: 200px;
  16. height: 200px;
  17. background-color: aqua;
  18. transition: all 0.5s;
  19. margin: 200px auto;
  20. }
  21. div:hover {
  22. transform: translate3d(0, 0, 200px);
  23. }
  24. </style>
  25. </head>
  26.  
  27. <body>
  28. <div>
  29.  
  30. </div>
  31. </body>
  32.  
  33. </html>

3、动画 animation

(1)、 animation: animation- name || animation- duration||  animation- timing-function || animation- delay || animation- iteration-count||  animation- direction||  animation- fill-mode;

animation-name:动画名称(自己使用@keyframes 定义的动画)

animation-duration:持续时间

animation-timing-function:运动曲线,与过渡的运动曲线类似。

animation-delay:延迟时间

animation-iteration-count:循环次数 (infinite 是无限循环)

animation-direction:是否反向(动画是否是由结尾倒开是倒着放的)

animation-fill-mode:设置在动画播放之外的状态(结束时的状态)none | forwards(设为结束时的状态)| backwards(设为开始时的状态)|both(设为开始或结束时的状态)

animation-play-state:设置动画状态 running 开始|paused 暂停

(2)、@keyframes 自定义动画

格式如下

  1. @keyframes 动画名称 {
  2. from{ 开始} 0%
  3. to{ 结束 } 100%
  4. }

可以用 from...to 来指定动画过程,也可以用0%~100%指定动画过程。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3.  
  4. <head>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>Document</title>
  9. <style>
  10. div {
  11. width: 100px;
  12. height: 100px;
  13. background-color: aqua;
  14. /* animation: 动画名称 动画时间 运动曲线 何时开始 播放次数 是否反方向 */
  15. animation: move 5s linear 3;
  16. }
  17. @keyframes move {
  18. 0% {
  19. transform: translate3d(0, 0, 0);
  20. }
  21. 25% {
  22. transform: translate3d(400px, 0, 0);
  23. }
  24. 50% {
  25. transform: translate3d(400px, 300px, 0);
  26. }
  27. 75% {
  28. transform: translate3d(0, 300px, 0);
  29. }
  30. 100% {
  31. transform: translate3d(0, 0, 0);
  32. }
  33. }
  34. </style>
  35. </head>
  36.  
  37. <body>
  38. <div></div>
  39. </body>
  40.  
  41. </html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号