【尚硅谷】HTML5+CSS3学习笔记 (七)CSS动画(含大量源码)

2023-05-16

(七)CSS动画


== 本部分更多内容欢迎订阅专栏HTML+CSS学习专栏,将持续更新==

目录:

  • (七)CSS动画
    • 7.1 过渡(transition):
      • 7.1.1 transition-property:
      • 7.1.2 transition-duration:
      • 7.1.3 transition-timing-function:
      • 7.1.4 transition-delay:
    • 7.2 动画:
    • 7.3 变形:
      • 7.3.1 transform:
      • 7.3.2 rotate:
      • 7.3.3 scale:

7.1 过渡(transition):

通过过渡可以指定一个属性发生变化时的切换方式

通过过渡可以创建一些非常好的效果,提升用户的体验

7.1.1 transition-property:

  • 指定要执行过渡的属性
  • 多个属性间使用,隔开
  • 如果所有属性都需要过渡,则使用all关键字
  • 大部分属性都支持过渡效果,注意过渡时必须是从一个有效数值向另外一个有效数值进行过渡
transition-property: height , width;
transition-property: all;

7.1.2 transition-duration:

指定过渡效果的持续时间

时间单位:s 和 ms 1s = 1000ms

transition-duration: 100ms, 2s;
transition-duration: 2s;

7.1.3 transition-timing-function:

过渡的时序函数

指定过渡的执行的方式

可选值:

  • ease 默认值,慢速开始,先加速,再减速
  • linear 匀速运动
  • ease-in 加速运动
  • ease-out 减速运动
  • ease-in-out 先加速 后减速
  • cubic-bezier() 来指定时序函数(贝塞尔曲线)https://cubic-bezier.com
  • steps() 分步执行过渡效果,可以设置一个第二个值:
    • end , 在时间结束时执行过渡(默认值)
    • start , 在时间开始时执行过渡
transition-timing-function: cubic-bezier(.24,.95,.82,-0.88);
transition-timing-function: steps(2, start);

7.1.4 transition-delay:

过渡效果的延迟,等待一段时间后在执行过渡

transition-delay: 2s;

transition 可以同时设置过渡相关的所有属性,只有一个要求,如果要写延迟,则两个时间中第一个是持续时间,第二个是延迟

transition:2s margin-left 1s cubic-bezier(.24,.95,.82,-0.88);

示例:(移入阴影区域开始移动)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>

    <style>
        *{
            margin: 0;
            padding: 0;
        }

        .box1{
            width: 800px;
            height: 800px;
            background-color: silver;
            overflow: hidden;
        }

        .box1 div{
            width: 100px;
            height: 100px;
            margin-bottom: 100px;
            margin-left: 0;
        }

        .box2{
            background-color: #bfa;
             transition:2s margin-left 1s cubic-bezier(.24,.95,.82,-0.88);
        }

        .box3{
            background-color: orange;
            transition-property: all;
            transition-duration: 2s;
        }

        .box1:hover div{
            margin-left: 700px;
        }
    </style>

</head>
<body>

    <div class="box1">
        <div class="box2"></div>
        <div class="box3"></div>
    </div>
    
</body>
</html>

7.2 动画:

动画和过渡类似,都是可以实现一些动态的效果,不同的是过渡需要在某个属性发生变化时才会触发,动画可以自动触发动态效果。

设置动画效果,必须先要设置一个关键帧,关键帧设置了动画执行每一个步骤

        @keyframes test {
            /* from表示动画的开始位置 也可以使用 0% */
            from{
                margin-left: 0;
                background-color: orange;
            } 

            /* to动画的结束位置 也可以使用100%*/
            to{
                background-color: red;
                margin-left: 700px;
            }
        }

        .box2{
            background-color: #bfa;
            animation: test 2s 2 1s alternate;  
        }

动画的相关变量与过渡的类似:

  • animation-name: 要对当前元素生效的关键帧的名字
  • animation-duration: 动画的执行时间
  • animation-delay: 动画的延时
  • animation-timing-function: 动画执行的方式
  • animation-iteration-count: 动画执行的次数 (infinite 无限执行)
  • animation-direction: 指定动画运行的方向
    • normal 默认值 从 from 向 to运行 每次都是这样
    • reverse 从 to 向 from 运行 每次都是这样
    • alternate 从 from 向 to运行 重复执行动画时反向执行
    • alternate-reverse 从 to 向 from运行 重复执行动画时反向执行
  • animation-play-state:设置动画的执行状态
    • running 默认值 动画执行
    • paused 动画暂停
  • animation-fill-mode: 动画的填充模式
    • forwards 动画执行完毕元素会停止在动画结束的位置
    • backwards 动画延时等待时,元素就会处于开始位置
    • both 结合了forwards 和 backwards

示例:小球下落(可通过%控制不同关键帧)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>

        .outer{
            height: 500px;
            border-bottom: 10px black solid;
            margin: 50px auto;
            overflow: hidden;
        }
        .outer div{
            float: left;
            width: 100px;
            height: 100px;
            border-radius: 50%;
            background-color: #bfa;
            animation: ball .5s forwards linear infinite alternate;
        }

        div.box2{
            background-color: orange;
            animation-delay: .1s;
        }

        div.box3{
            background-color: yellow;
            animation-delay: .2s;
        }

        div.box4{
            background-color: yellowgreen;
            animation-delay: .3s;
        }

        div.box5{
            background-color: blue;
            animation-delay: .4s;
        }
        div.box6{
            background-color: pink;
            animation-delay: .5s;
        }
        div.box7{
            background-color: tomato;
            animation-delay: .6s;
        }
        div.box8{
            background-color: skyblue;
            animation-delay: .7s;
        }
        div.box9{
            background-color: chocolate;
            animation-delay: .8s;
        }

        /* 创建小球下落的动画 */
        @keyframes ball {
            from{
                margin-top: 0;
            }

            to{
                margin-top: 400px;
            }

            /* 2                                    to{
                margin-top: 400px;
                animation-timing-function: ease-in;
            }

            40%{
                margin-top: 100px;
            }

            80%{
                margin-top: 200px;
            } */

        }
    </style>
</head>
<body>

    <div class="outer">
        <div class="box1"></div>
        <div class="box2"></div>
        <div class="box3"></div>
        <div class="box4"></div>
        <div class="box5"></div>
        <div class="box6"></div>
        <div class="box7"></div>
        <div class="box8"></div>
        <div class="box9"></div>
    </div>
    
</body>
</html>

7.3 变形:

变形就是指通过CSS来改变元素的形状或位置

变形不会影响到页面的布局,不会脱离文档流

7.3.1 transform:

transform 用来设置元素的变形效果

  • translateX() 沿着x轴方向平移
  • translateY() 沿着y轴方向平移
  • translateZ() 沿着z轴方向平移

平移元素,百分比是相对于自身计算的

transform: translateY(-100px);
transform: translateX(100%);

让元素水平居中:

left: 50%;
top: 50%;
transform: translateX(-50%)translateY(-50%);

卡片浮出效果:

        .box4, .box5{
            width: 220px;
            height: 300px;
            background-color: #fff;
            float: left;
            margin: 0 10px;
            transition:all .3s;
        }

        .box4:hover,.box5:hover{
            transform: translateY(-4px);
            box-shadow: 0 0 10px rgba(0, 0, 0, .3) 
        }

z轴平移,调整元素在z轴的位置,正常情况就是调整元素和人眼之间的距离,距离越大,元素离人越近

z轴平移属于立体效果(近大远小),默认情况下网页是不支持透视,如果需要看见效果,必须要设置网页的视距

html{
            /* 设置当前网页的视距为800px,人眼距离网页的距离 */
            perspective: 8000px;
        }
 body:hover .box1{
            transform: translateZ(800px);
        }

7.3.2 rotate:

通过旋转可以使元素沿着x y 或 z旋转指定的角度

示例:卡片翻转效果

        html{
            perspective: 800px;
        }
		body:hover .box1{
            /* transform: rotateZ(.25turn); */
            /* transform: rotateY(180deg) translateZ(400px); */
            /* transform: translateZ(400px) rotateY(180deg) ; */
            transform: rotateY(180deg);
            /* 是否显示元素的背面 */
            backface-visibility: hidden;

        }

7.3.3 scale:

对元素进行缩放的函数:

  • scaleX() 水平方向缩放
  • scaleY() 垂直方向缩放
  • scale() 双方向的缩放
transform:scale(1.2);
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        html{
            perspective:800px;
            
        }
        .box1{
            width: 100px;
            height: 100px;
            background-color: #bfa;
            transition:2s;
            margin: 100px auto;
        }

        .box1:hover{
            transform:scale(2)
        }


        .img-wrapper{
            width: 200px;
            height: 200px;
            border: 1px red solid;
            overflow: hidden;
        }

        img{
            transition: .2s;
        }

        .img-wrapper:hover img{
            transform:scale(1.2);
        }

    </style>
</head>
<body>
    
    <div class="box1"></div>

    <div class="img-wrapper">
        <img src="an.jpg" width="100%">
    </div>


</body>
</html>

参考教程:尚硅谷 HTML+CSS b站教程

以上就是本章节的笔记整理,后续也会继续坚持更新我的HTML+CSS学习笔记。

如有错误,欢迎提出指正,在评论区和我一起交流。

往期回顾:
(一)HTML简介
(二)CSS基础
(三)CSS布局
(四)CSS浮动
(五)CSS定位
(六)CSS字体背景

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【尚硅谷】HTML5+CSS3学习笔记 (七)CSS动画(含大量源码) 的相关文章

  • openstack-keystone

    目录 一 keystone身份服务二 keystone的主要功能三 keystone相关概念四 keystone认证流程五 OpenStack Keystone组件部署步骤部署步骤 一 keystone身份服务 keystone xff08
  • k8s-----------YAML&harbor

    目录 概述使用YAML文件创建资源1 查看资源版本的标签2 创建yaml文件测试 Pod1 特点2 pod容器分类3 镜像拉取策略 部署harbor1 登录harbor私有仓库2 下载Tomcat镜像进行推送3 推送 概述 Kubernet
  • k8s-----------高级pod&调度

    目录 pod进阶pod重启策略 健康检查 探针调度约束调度方式 故障排除 pod进阶 limits cup cpu上限limits memory 内存上限requests cpu 创建时分配的基本CPU资源requests memory 创
  • k8s-----------控制器

    目录 Deployment 部署无状态应用 Pod与控制器之间的关系 SatefulSet xff08 部署有状态应用 xff09 无状态和有状态无状态有状态 常规service和无头服务区别DaemonSetjobCronJob 控制器
  • 安装electron时安装失败解决

    错误描述 xff1a 在安装 electron 的时候 xff0c 使用官方推荐的如下命令 xff1a npm install save dev electron 结果报错如下 npm ERR code 1 npm ERR path D A
  • 10:天干地支

    10 天干地支 时间限制 1 S 内存限制 8192 KB Accept 15 Submit 41 提交 讨论版 描述 天干地支 xff0c 源自中国远古时代对天象的观测 甲 乙 丙 丁 戊 己 庚 辛 壬 癸 称为十天干 xff0c 子
  • txt格式vscode转码

    txt打开异常 xff0c 或乱码 右下角有格式类型 xff1a utf 8 xff0c 点击它会有一个 select action 弹框 可选择特定格式重新打开 xff0c 或保存 选择好对应的格式 乱码解决 或者点击 save with
  • 送给 Java 程序员的 Spring 学习指南

    https www infoq cn article Ad 8ghcGGCNU572U6oEX 学习 Spring 的基础要求 Spring 官网首页是这么介绍自己的 Spring the source for modern Java xf
  • Centos下如果是二进制文件,编辑是文本,后缀是sh也无法执行

    这次部署redis遇到个问题 xff0c 执行sh文件来启动redis xff0c 结果报配置文件无法打开 用vi打开sh文件反复检查过路径是对的 然后手敲路径执行 xff0c 运行正常 xff1b 直接执行sh文件不行 xff1a 反复修
  • Python Pandas 查看数据信息 DataFrame.info()

    在进行数据分析之前 xff0c 需要先查看数据的信息 xff0c 这样才方便后续的数据处理 比如 xff0c 在excel表中20220520是一个常规类型的数据 xff0c 那它导入到DataFrame中是int类型还是str类型呢 xf
  • 03-1.MariaDB安装配置详细步骤

    Author xff1a Sickey Date xff1a 2021 11 25 安装前准备 配置静态IP防火墙等等 1 安装mariadb数据库 先查看RDO中MariaDB的版本及配置 etc my cnf d server cnf
  • 24行代码简单实现qq空间自动点赞

    什么是Auto js xff1f Auto js是基于JavaScript语言运行在Android平台上的工具 它依赖于无障碍服务 它可以做什么 xff1f 解放双手 xff0c 让手机自动打游戏 自动签到 自动领红包等等等等 它有什么优点
  • 操作系统(C++)——生产者消费者模型

    一 C 43 43 实现代码 span class token macro property span class token directive hash span span class token directive keyword i
  • 2023.03.14java内置的线程池 -》 ScheduledExecutorService 具备延迟运行的能力!的使用

    区别 ScheduledExecutorService xff0c 执行任务方法为schedule xff0c 而不是submit es schedule new MyRunnable i 2 TimeUnit SECONDS 指定线程了线
  • sudo rm -rf /* 命令运行演示(管理员身份删除根目录所有文件)

    一 前言 闲来无事 xff0c 好奇传说中的 sudo rm rf 命令究竟有什么样的魅力让无数人趋之若鹜 xff0c 本着奉献精神 xff0c 作者将在自己的服务器上测试一番 xff0c 各位读者切勿轻易尝试 不 xff0c 切勿尝试 x
  • 服务器如何安装宝塔面板?

    一 前言 作者是按照宝塔面板官方指引进行下载的 xff0c 中间进行更为清晰明了的图示说明 宝塔官方说明 xff08 或者直接按下面步骤安装 xff09 xff1a 宝塔Linux面板安装教程 2021年8月18日更新 7 7 0正式版 L
  • 计算机网络体系结构(详图)

    本文旨在作学习记录 xff0c 其中 xff0c 图源的信息已标明 图源 xff1a 谢希仁的 计算机网络 图源 xff1a 网络
  • wordpress+宝塔在阿里云服务器上搭建个人博客(如何在服务器上搭建个人博客)

    目录 一 宝塔安装 1 开放端口 2 命令安装 二 环境安装 xff08 LNMP xff09 三 wordpress安装包下载 四 部署站点 四 博客访问 五 结语与参考 一 宝塔安装 宝塔官方安装教程 xff08 或者直接按下面步骤安装
  • docker-compose安装教程(包含docker安装教程)

    本文旨在学习记录 xff0c 该过程是作者经历过大大小小的十来次失败总结而来 xff0c 内容都是各方博客荟萃的结果 xff0c 下述内容都已实践成功 xff0c 若失败 xff0c 只需初始化云盘 xff0c 重新安装即可 xff0c 无
  • Idea中xml文件局部黄色背景颜色去除

    Idea中xml文件局部黄色背景颜色去除 参考 xff1a Idea中更改主题后xml配置文件局部黄色背景颜色去除 版本2020 3 初始打开 xff0c 或更换主题后 xff0c 黑色背景屎黄色 xff0c 白色背景浅黄色或青绿色 Int

随机推荐