🤓
blog-article
  • Introduction
  • 面试题
    • 1. 输入url发生了什么
  • Personal Works
    • 1. 简单的Web图床
  • CSS动画笔记
    • 1.transition 属性
    • 2.transition 实例
  • css 笔记
    • 1. box-shadow 阴影
    • 2. columns 设置列宽和列数
    • 3. 伪元素after与before
  • html 笔记
    • 1. 不常用的h5标签杂记
  • webpack4
    • 1. 文档学习记录
    • 2. 加载CSS
    • 3. 加载less
    • 4. 加载sass
    • 5. 根据浏览器自动添加css前缀
    • 6. 图片文件处理
    • 7. 字体文件处理
    • 8. 引入jQuery
    • 9. 打包HTML文件
    • 10. 分离css插件
    • 11. babel简单使用
    • 12. 清理旧打包文件插件
    • 13. 拷贝静态资源
  • javascript
    • 1. js获取某年某月的天数
  • npm
    • 2. JSON.stringify()完整用法
    • 1. 入门篇
    • 2. 进阶篇
  • Node.js
    • 1. 使用koa-body中间件后ctx.request.body内容为空
    • 2. uni-app使用Node+Koa2接收上传的文件
  • SQL
    • 1. 查询
    • 2. 插入
    • 3. 修改
    • 4. 删除
    • 5. 期末复习
  • Git
    • 1. git add命令后出现another git process...问题
    • 2. 将文件从暂存区移除
  • vue-cli
    • 1. vue-cli(脚手架)引入vue.config.js文件后热更新失效,每次保存都会刷新页面
  • uni-app
    • 1. uni-app中不使用scroll-view组件,监听页面滑直底部事件
  • 设计模式
    • 创建型模式
    • 单例模式
    • 工厂模式
    • 抽象工厂模式
  • Spring boot
    • 1. 使用自定义参数注解获取 token 中User数据
  • IDEA
    • 1. 设置maven项目的默认配置
  • Linux
    • 1.常用命令
    • 2.常用基础命令2
    • 3.linux目录介绍
    • 4. vi编辑器使用
    • 5.用户管理
    • 6. 文件属性与权限操作
    • 7. 文件归档与解压缩
    • 8. gcc的基本用法
    • 9. gdb调试器的基本用法
    • 10. Makefile基本用法
  • shell
    • shell与crontab定时器的结合
    • 1. shell 变量与常见符号
    • 2. shell中的四则运算符
    • 3. 条件判断
    • 4. 输入输出
    • 5. 输出彩色的内容
    • 6. 流程控制
    • 7. 函数
  • Docker
  • 嵌入式系统给结构及原理
  • 学校课程笔记
    • 1. java EE 复习
    • 2. 马原复习论述题
    • 3. 嵌入式软件技术复习
    • 4. 嵌入式操作系统复习
    • 5. 马原选择题
    • 6. 马原辨析题
    • 7. 马原材料题
    • 8. 计网学习笔记
    • 9. 计网复习
      • 1. 第一章
Powered by GitBook
On this page
  • 简介
  • 简单用法
  • 代码
  • 意义
  • 示例
  • 简写transition全部参数
  • transition全写
  • 时间函数Steps()
  • 参数
  • 示例
  • 添加多个过渡
  • 添加移除类触发过渡

Was this helpful?

  1. CSS动画笔记

1.transition 属性

PreviousCSS动画笔记Next2.transition 实例

Last updated 5 years ago

Was this helpful?

简介

transition(过渡)) 是指从一个状态到另一个状态的变化。比如当鼠标在某个元素上悬停时,我们会修改它的样式,采用 transition 可以创建一个平滑的动画效果。

简单用法

代码

transition: background 0.5s linear;

意义

在 0.5 秒的时间里,按照 linear 的时间函数(timing-function)来改变某个元素的 background 属性。

示例

当鼠标在按钮上悬停时(hover)改变按钮的 background。

  • html

      <button>按钮</button>
  • css

      button {
          padding:1em 2em;
          background: #fff;
          transition: background 1s linear;
      }
    
      button:hover {
          background: deeppink;
      }
  • 效果

如果我们把 transition: background 1s linear 放到hover中则只有鼠标离开时才有动画效果;

简写transition全部参数

transition:[property] [duration] [delay] [timeing-function]

transition全写

  • transition-property:all; / 规定过渡css属性名称 /

  • transition-duration: 1s;/ 过渡持续时间 3s===31000ms */

  • transition-delay: 0.1s;/ 过渡效果延迟开始时间 /

  • transition-timing-function: ease-in;/ 时间函数 /

时间函数Steps()

参数

  1. 动画完成步数

    • 参数类型:Number

  2. 第一个步进点

    • 参数:start/end

    • 默认:end

示例

  • html

      <div id="block"></div>
  • css

      #block{
          position: absolute;
          left: 50%;
          top: 30%;
          transform: translateX(-50%);
          width: 12em;
          height: 12em;
          background: #000;
          transition: all 1s steps(5,end);
          /*transition: all 1s linear;*//*平滑过渡*/
      }
    
      #block:hover{
          width: 2em;
          height: 2em;
      }
  • 效果

添加多个过渡

  • html

      <div id="block"></div>
  • css

      #block{
          position: absolute;
          left: 50%;
          top: 30%;
          transform: translateX(-50%);
          width: 12em;
          height: 12em;
          background: #000;
          transition: width 1s linear,height 1s linear,background 1s ease-in-out;
      }
    
      #block:hover{
          background: burlywood;
          width: 2em;
          height: 2em;
      }
  • 效果

添加移除类触发过渡

简单示例

  • 效果

  • html

<body>
    <button id="show">Show it</button>
    <div id="wait-show" class="hide">
        <h1>Title</h1>
        <p>Pressing the button shows this content.</p>
    </div>
</body>
  • css

body {
  background-color: #134;
  transition: background 0.5s ease-out;
  font-family: HelveticaNeue, Arial, Sans-serif;
}
body.on {
  background-color: #099;
}

button{
  background: transparent;
  border: 2px solid #fff;
  border-radius: 1em;
  color: #fff;
  cursor: pointer;
  font-size: 24px;
  padding: 1em 2em;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: all 0.4s ease-out;
  outline: 0;
}

button:hover{
  background: #fff;
  color: #099;
}

#wait-show{
  color: #fff;
  text-align: center;
  position: absolute;
  left: 50%;
  transform: translate(-50%,-50%);
  transition: all 0.5s cubic-bezier(.83,-0.43,.21,1.42);
}

.hide{
  opacity: 0;
  top:calc(50% + 10em);
}

.show{
  opacity: 1;
  top: calc(50% + 6em);
}
  • js

 let showBtn = document.getElementById('show');
    let body = document.body;
    let waitShow = document.getElementById('wait-show');

    /**
    * 监听点击事件
    */
    showBtn.addEventListener('click', function (e) {
        // 更改body颜色
        body.className = body.className === 'on' ? '' : 'on';

        waitShow.className = waitShow.className === 'hide' ? 'show' : 'hide';
    })
    document.getElementsByTagName('body')
深度录屏_选择区域_20191108082955-201911883119
深度录屏_选择区域_20191108084146-201911884225
深度录屏_选择区域_20191108085505-201911885546
深度录屏_选择区域_20191108030921-201911831515