1-2-11【CSS3】CSS过渡属性

题外话:这节课非常有意思哦~可以让元素动起来啦


文章内容输出来源:拉勾教育大前端就业集训营

1.概述

  • CSS3出现之前,前端一般使用Flash动画或JavaScript制作动画。
  • flash采用帧动画的形式制作动画,通过一帧一帧的画面按照固定的顺序和速度播放,比如说老式胶片电影。

老式胶卷电影的经典开头。

2.过渡属性

  • 概述:在不使用Flash和js的情况下,使用过度属性可自动实现动画效果。
    当前元素只要有“属性”发生变化时,即存在A和B两种状态,使用过渡属性,即可实现A和B之间的平滑过渡动画效果。

  • 属性写法:transition:过渡的属性 过渡时间 运动曲线 延时时间;

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box{
            width: 100px;
            height: 100px;
            background-color: pink;
            transition: width 0.2s linear 0s;
        }
        .box:hover{
            width: 200px;
            height: 150px;
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

说明:transition设置的意思是:“当该元素的width属性发生变化时,使变化过渡0.2s实现,使用线性的变化方式,延迟0s开始过渡。
因为transition属性没有监视height属性,所以就算height变化了,也是直接变化而没有过渡动画。

单一属性

transition-property过渡的属性
  • 属性值
    • none:表示没有属性过渡;
    • all:表示所有变化的属性都过渡;
    • 属性名:使用具体属性名,多个属性名用逗号隔开。

transition-duration和transition-delay

  • 概述:duration是过渡的时间长度,delay是在过渡前的延迟时间。
  • 属性值:以s为单位的时间长度,就算是0也要加单位s。

transition-timing-function时间曲线

  • 概述:动画在播放时遵循的时间曲线。
  • 属性值
属性值 描述
linear 规定以恒定的速度实现从开始到结束的效果
ease 规定慢速开始,然后变快,然后慢速结束的效果
ease-in 规定以慢速开始,逐渐加速的效果
ease-out 规定以快速开始,逐渐减速的效果
ease-in-out 规定以慢速开始和结束的效果
cubic-bezier(x1,y1,x2,y2) 用两个点的坐标值,计算出一条贝塞尔曲线,作为动画的时间曲线

说明:如图所示,贝塞尔曲线是由两个点计算得到的一条时间曲线,所以在cubic-bezier()中,只需要提供两个点,就可以指定一条你自定义的时间曲线。

兼容性:IE10、Firefox、Chrome以及Opera浏览器支持transition属性。Safari需要加前缀-webkit-。

3.2D转换

  • 概述:对元素进行移动、缩放、旋转、拉长或拉伸。配合过渡和即将学习的动画知识,几乎可以完全取代Flash。
  • 属性名:transform
  • 属性值:根据不同的属性值,实现不同的2D转换。

注意! transform是一个独立的属性,并不需要搭配transition才能生效。我只是为了例子更加直观所以才一起写的,不要被误导哦~

位移 translate()
  • 概述:对元素进行水平&垂直方向上的移动。
  • 书写语法
属性值 说明
translate(x,y) x,y分别是水平和垂直方向的距离,可以为px也可以为%
translate(x) 只有一个数值,表示水平方向的位移
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 100px;
            height: 100px;
            background-color: pink;
            border-radius: 50%;
            transition: all 0.5s linear 0s;
        }
        div:hover{
            /* 位移属性 */
           transform: translate(100px,100px);
        }
    </style>
</head>
<body>
    <div></div>
</body>
</html>

说明:利用伪类选择器hover,实现鼠标移动至盒子上方时,盒子向右向下各位移100像素。

缩放 scale()
  • 概述:在元素的宽高两个维度对元素进行缩放。
  • 书写语法
属性值 说明
scale(x,y) x,y分别是改变宽度和高度的倍数
scale(n) 只有一个数值,表示宽高同时缩放n倍
scaleX(n) 改变元素的宽度
scaleY(n) 改变元素的高度
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 100px;
            height: 100px;
            background-color: pink;
            border-radius: 50%;
            transition: all 0.5s linear 0s;
        }
        div:hover{
            /* 缩放 */
            transform: scale(0.5,1.5);
        }
    </style>
</head>
<body>
    <br>
    <br>
    <br>
    <div></div>
</body>
</html>

说明:如图所示,缩放盒子的宽度为50%,缩放盒子的高度为150%。

旋转 rotate()
  • 概述:在元素的宽高两个维度对元素进行缩放。
  • 书写语法:transform: rotate(数字deg)
    • 说明:deg为度数单位,正数为顺时针旋转,负数为逆时针旋转。
    • 注意:元素旋转后坐标轴也会发生变化!
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 100px;
            height: 100px;
            position: relative;
            left: 50px;
            top: 50px;
            transition: all 0.5s linear 0s;
        }
        .box2{
            background-color: pink;
        }
        .box2:hover{
            transform: rotate(45deg) translate(100px);
        }
        .box1{
            background-color: red;
        }
        .box1:hover{
            transform: translate(100px) rotate(45deg) ;
        }
    </style>
</head>
<body>
    <div class="box1"></div>
    <br>
    <div class="box2"></div>
</body>
</html>

说明:因为旋转后,元素的坐标轴也会跟着旋转,所以旋转后的位移会以新的坐标轴为基准进行旋转,就导致了粉色盒子的情况。而同比红色的盒子,是先位移后旋转,位移时坐标轴没有受到影响,所以符合我们的预期。

倾斜 skew()
  • 概述:在元素的水平方向和垂直方向上进行2D倾斜。
  • 书写语法:transform: skew(数字deg,数字deg);
  • 注意:两个属性值分别表示水平和垂直方向倾斜的角度,属性值可以为正可以为负,第二个数值不写默认为0。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 150px;
            height: 100px;
            background-color: pink;
            transition: all 0.5s linear 0s;
            position: relative;
            top: 50px;
            left: 50px;
        }
        div:hover{
            transform: skew(30deg);
        }
    </style>
</head>
<body>
    <div></div>
</body>
</html>

说明:此处以“在水平方向的倾斜”为例,注意,虽然倾斜了,但是坐标轴并没有发生变化。

transform-origin属性
  • 概述:调整元素的水平和垂直方向基准点的位置。
  • 作用:主要用于旋转,旋转是以元素的基准点进行变换的,基准点的位置不同,旋转的效果也不同。
  • 书写方式:transform-origin: 水平方向 垂直方向;
  • 属性值
    • 水平方向:可以使用关键字left、center、right以及像素值和百分比。
    • 垂直方向:可以使用关键字top、center、bottom以及像素值和百分比。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            width: 150px;
            height: 100px;
            position: relative;
            transition: all 0.5s linear 0s;
            margin: 50px auto;
        }
        .box1{
            background-color: pink;
            transform-origin: center center;
        }
        .box1:hover{
            transform: rotate(45deg);
        }
        .box2{
            background-color: red;
            transform-origin: left top;
            margin: 0px auto;
        }
        .box2:hover{
            transform: rotate(45deg);
        }
    </style>
</head>
<body>
    <div class="box1"></div>
    <br>
    <div class="box2"></div>
</body>
</html>

说明:粉色盒子的基准点是盒子的正中心,所以旋转起来是以中心为基准顺时针旋转45°;而红色盒子的基准点是左上顶点,所以旋转起来是以左上顶点为中心顺时针旋转45°,两者效果因基准点位置不同而大相径庭。

前端文章汇总目录

https://www.jianshu.com/p/6d80dd616ff4


结束语:一花一世界,一木一浮生,愿与诸君共勉

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342