【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数

简介: transition过渡属性早期在Web中要实现动画效果,都是依赖于JavaScript或Flash来完成。但在CSS3中新增加了一个新的模块transition,它可以通过一些简单的CSS事件来触发元素的外观变化,让效果显得更加细腻。简单点说,就是通过鼠标经过、获得焦点,被点击或对元素任何改变中触发,并平滑地以动画效果改变CSS的属性值。在CSS中创建简单的过渡效果可以从以下几个步骤来实现:在默认样式中声明元素的初始状态样式;声明过渡元素最终状态样式,比如悬浮状态;在默认样式中通过添加

transition过渡属性

早期在Web中要实现动画效果,都是依赖于JavaScript或Flash来完成。
但在CSS3中新增加了一个新的模块transition,它可以通过一些简单的CSS事件来触发元素的外观变化,
让效果显得更加细腻。简单点说,就是通过鼠标经过、获得焦点,被点击或对元素任何改变中触发,
并平滑地以动画效果改变CSS的属性值。

在CSS中创建简单的过渡效果可以从以下几个步骤来实现:

  1. 在默认样式中声明元素的初始状态样式;
  2. 声明过渡元素最终状态样式,比如悬浮状态;
  3. 在默认样式中通过添加过渡函数,添加一些不同的样式。

CSS3的过渡transition属性是一个复合属性,主要包括以下几个子属性:
| 详细参数|说明|
|--|--|
|transition-property|指定过渡或动态模拟的CSS属性|
|transition-duration|指定完成过渡所需的时间|
|transition-timing-function|指定过渡函数|
|transition-delay|指定开始出现的延迟时间|

transition-property 模拟css属性

transition-property指定对THML元素的哪个css属性进行平滑渐变处理,该属性可以指定
例如background-color,width,height等各种标准的CSS属性。

特别注意:当“transition-property”属性设置为all时,表示的是所有中点值的属性。

用一个简单的例子来说明这个问题:
假设你的初始状态设置了样式“width”,“height”,“background”,当你在最终状态都改变了这三个属性,
那么all代表的就是“width”、“height”和“background”。
如果你的终始状态只改变了“width”和“height”时,那么all代表的就是“width”和“height”。

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>07动画--过渡属性 transition-property档</title>
<link href="css/style.css" rel="stylesheet" type="text/css"/>
</head>

<body>
<div></div>
</body>
</html>
@charset "utf-8";
/* CSS Document */
* {
   
    margin: 0;
    padding: 0;
}
div {
   
    width: 300px;
    height: 300px;
    margin: 100px auto;
    background-color: #900;
    /*transition:background-color 1s ease .2s;
    -webkit-transition: background-color .5s ease .1s;*/
    transition-property:background-color;
    transition:all 5s ease .2s;

    /*-webkit-transition: all .5s ease .1s;
    transition:all .5s ease .1s;*/
}
div:hover {
   
    /*width: 400px;
    height: 400px;*/
    background-color: #FF0;
}

/*在CSS中创建简单的过渡效果可以从以下几个步骤来实现:
第一,在默认样式中声明元素的初始状态样式;
第二,声明过渡元素最终状态样式,比如悬浮状态;
第三,在默认样式中通过添加过渡函数,添加一些不同*/

请牢记,transition过渡属性一定是放在需要显示过渡效果的元素中

transition-duration 过渡所需时间指定

transition-duration 属性主要用来设置一个属性过渡到另一个属性所需的时间,也就是从旧属性过渡到新属性花费的时间长度,俗称持续时间。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>08动画--过渡所需时间 transition-duration</title>
<link href="css/style.css" rel="stylesheet" type="text/css"/>
</head>

<body>
<div></div>
</body>
</html>
@charset "utf-8";
/* CSS Document */
* {
   
    margin: 0;
    padding: 0;
}
div {
   
    width: 300px;
    height: 200px;
    margin: 100px auto;
    background-color: #900;
    transition-property: all;
    /*-moz-transition-property: border-radius;
    -webkit-transition-property: border-radius;*/
    transition-duration: 1.5s;
    transition-timing-function:linear;
    /*-moz-transition-duration: .5s;
    -webkit-transition-duration: .5s;*/

}
div:hover {
   
    border-radius: 50%;
    background-color: #344FB3;
}

transition-timing-function 过渡函数

transition-timing-function 属性指的是过渡的“缓动函数”。

  • 主要用来指定浏览器的过渡速度,以及过渡期间的操作进展情况

其中要包括以下几种函数:
| 参数|说明|
|--|--|
|ease|默认值,动画开始时比较慢,然后加快速度,达到最大速度后再减慢速度。|
|linear|线性速度。动画开始时的速度和结束时的速度一样(匀速)。|
|ease-in|动画开始的速度较慢,然后速度加快。|
|ease-out|动画开始的速度很快,然后速度减慢。|
|ease-in-out|动画开始时比较慢,然后加快速度,达到最大速度后再减慢速度.|

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>09动画--过渡函数 transition-timing-function</title>
<link href="css/style.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div class="one"></div>
<div class="two"></div>
<div class="three"></div>
<div class="four"></div>
<div class="five"></div>
</body>
</html>
@charset "utf-8";
/* CSS Document */
* {
   
    margin: 0;
    padding: 0;
}
div {
   
    width: 200px;
    height: 100px;
    margin: 10px auto;
    background: #900;
    transition-property: border-radius;
    -webkit-transition-property: -webkit-border-radius;
    -moz-transition-property: -moz-border-radius;
    transition-duration: .5s;
    -webkit-transition-duration: .5s;
    -moz-transition-duration: .5s;
    transition-delay: .2s;/*transition-timing-function:ease;*/
    /*transition-timing-function:linear;*/
    /*transition-timing-function:ease-in;    */
    /*transition-timing-function:ease-out;*/    
    /*transition-timing-function:ease-in-out;    */
}
div:hover {
   
    border-radius: 100%;
}
.one {
   
    transition-timing-function: ease;
}
.two {
   
    transition-timing-function: linear;
}
.three {
   
    transition-timing-function: ease-in;
}
.four {
   
    transition-timing-function: ease-out;
}
.five {
   
    transition-timing-function: ease-in-out;
}
  • 示例2

    <!DOCTYPE html>
    <html>
    <head>
      <title></title>
      <style>
          #wrapper{
          
              width:1024px;
              margin:0 auto;
          }
          .progress-bar{
          
              height:40px;
              width:40px;
              background-color: #69c;
          }
          .progress-bar:hover{
          
              width:960px;
          }
    
          #bar1{
          
              -webkit-transition: width 5s linear;
          }
          #bar2{
          
              -webkit-transition: width 5s ease;
          }
          #bar3{
          
              -webkit-transition: width 5s ease-in;
          }
          #bar4{
          
              -webkit-transition: width 5s ease-out;
          }
          #bar5{
          
              -webkit-transition: width 5s ease-in-out;
          }
      </style>
    </head>
    <body>
    
      <div id="wrapper">
          <p>linear</p>
          <div class="progress-bar" id="bar1"></div>
    
          <p>ease</p>
          <div class="progress-bar" id="bar2"></div>
    
          <p>ease-in</p>
          <div class="progress-bar" id="bar3"></div>
    
          <p>ease-out</p>
          <div class="progress-bar" id="bar4"></div>
    
          <p>ease-in-out</p>
          <div class="progress-bar" id="bar5"></div>
      </div>
    </body>
    </html>
    

    transition-delay 过渡时间延迟

    transition-delay属性和transition-duration属性极其类似,不同的是 transition-duration 是用来设置过渡动画的持续时间,而transition-delay主要用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行。

有时我们想改变两个或者多个css属性的transition效果时,只要把几个transition的声明串在一起,用逗号(“,”)隔开,然后各自可以有各自不同的延续时间和其时间的速率变换方式。
但需要值得注意的一点:

  • 第一个时间的值为 transition-duration,第二个为transition-delay。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>10动画--过渡延迟时间 transition-delay</title>
<link href="css/style.css" rel="stylesheet" type="text/css"/>
</head>

<body>
    <div class="wrapper">
        <div><span>请把鼠标放我这儿</span></div>
    </div>
</body>
</html>
@charset "utf-8";
/* CSS Document */
* {
   
    margin: 0;
    padding: 0;
}
.wrapper {
   
    width: 400px;
    height: 400px;
    margin: 100px auto;
    border:2px dotted #906;
}
.wrapper div{
   
    width:200px;
    height:200px;
    line-height:200px;
    text-align:center;
    font-size:20px;
    color:#fff;
    background-color:#90F;
/*    transition-property:all;
    transition-duration:3s;
    transition-timing-function:linear;
    transition-delay:1s;*/
    transition:all 3s ease-in;
        /*transition:all 1s ease-in .1s;*/
/*    -webkit-transition:all 1s ease-in .1s;
    -moz-transition:all 1s ease-in .1s;*/
}
.wrapper div:hover{
   
    width:300px;
    height:300px;
    background-color:#F39;
}

🤩CSS教学往期回顾

  1. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
  2. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
  3. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
  4. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
  5. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
  6. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
  7. 【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数

    💕👉博客专栏

目录
相关文章
|
6月前
|
前端开发 JavaScript 算法
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
transform变形 css3在原来的基础上新增了变形和动画相关属性,通过这些属性可以实现以前需要大段JavaScript才能实现的 功能。 CSS3的变形功能可以对HTML组件执行位移、旋转、缩放、倾斜4种几何变换,这样的变换可以控制HTML组件 呈现出丰富的外观。 借助于位移、旋转、缩放、倾斜这4种几何变换,CSS3提供了transition动画。 transition动画比较简单,只要指定HTML组件的哪些CSS属性需要使用动画效果来执行变化,并指定动画时间,就可保证动画播放。 比transitio
317 1
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
Animation属性 css3为Animation动画提供的几个属性如下: 属性名 属性值 animation-name 指定动画名称,该属性指定一个已有的关键帧定义。 animation-duration 指定动画持续时间。 animation-timing-funtion 指定动画变化速度。 animation-delay 指定动画延迟多长时间才开始执行。 animation-iteration-count 指定动画的循环执行次数。 animation:这是一个复合属性。
424 3
|
10月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
人工智能 程序员 UED
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
776 21
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
前端开发 JavaScript
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
597 14
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
前端开发
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
677 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
css3 svg制作404页面动画效果HTML源码
css3 svg制作404页面动画效果HTML源码
284 34
html+js+css实现的建筑方块立体数字时钟源码
html+js+css实现的建筑方块立体数字时钟源码
602 33
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML和CSS之旅
【9月更文挑战第32天】在这个数字化的时代,拥有一个个人博客不仅是展示自我的平台,也是技术交流的桥梁。本文将引导初学者理解并实现一个简单的个人博客网站的搭建,涵盖HTML的基础结构、CSS样式的美化技巧以及如何将两者结合来制作一个完整的网页。通过这篇文章,你将学会如何从零开始构建自己的网络空间,并在互联网世界留下你的足迹。