CSS3 Transition

本文详细介绍了CSS中的transition属性,包括过渡效果的四个关键属性:transition-property、transition-duration、transition-timing-function和transition-delay。通过实例演示了如何设置多个属性同时过渡、带有延迟的过渡效果以及应用于菜单项的高亮过渡。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

transition (过渡) 属性:允许 css 的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变css的值

 transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* 

transition 主要包含以下四个属性:

1、transition-property 执行过渡的属性

用来指定当元素其中一个属性改变时,执行 transition 效果。主要有以下几个值:

none:没有属性改变。为 none时,transition 马上停止执行

all:所有属性改变(默认值)。为 all 时,元素产生任何属性值变化时都将执行 transition 效果

indent:元素属性名 (如:width,color,background-color,vertical-align,top,left,border-width 等)

 

2、transition-duration 过渡延续的时间

transition-duration : <time> [, <time>]* 

用来指定元素过渡过程的持续时间,取值为数值,单位为s 或 ms。默认值是 0

可以作用于所有元素,包括 :before 和 :after 伪元素

 

3、transition-timing-function 在延续时间段,过渡的速率变化

transition-timing-function : ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>) [, ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>)]* 

允许你根据时间的推进去改变属性值的过渡速率,有6个取值

ease逐渐变慢默认值。规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0.25,0.1,0.25,1))
linear匀速规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1))
ease-in加速  规定以慢速开始的过渡效果(等于 cubic-bezier(0.42,0,1,1))
ease-out减速规定以慢速结束的过渡效果(等于 cubic-bezier(0,0,0.58,1))
ease-in-out加速然后减速规定以慢速开始和结束的过渡效果(等于 cubic-bezier(0.42,0,0.58,1))
cubic-bezier(x1, y1, x2, y2)自定义一个时间曲线在 cubic-bezier 函数中定义自己的值。(x1,y1,x2,y2) 四个值特定于曲线上点P1(x1,y1) 和 点P2(x2,y2)。所有值须在[0,1]区域内,否则无效

 

 

 

 

 

 

 

4、transition-delay 过渡延迟时间

transition-duration : <time> [, <time>]* 

用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行 transition 效果。

取值为数值,单位为 s 或 ms,默认值是 0,也就是过渡立即执行,没有延迟

 

简写语法:

div {
    transition: <property> <duration> <timing-function> <delay>;
}

DEMO 1: 多个属性一起过渡

<div class="demo1">
      <p>盒子的多个属性一起动画: width, height, background-color, transform. 将光标悬停在盒子上查看动画。</p>
      <div class="box"></div>
</div>
.demo1{
  .box{
    width: 100px;
    height: 100px;
    border: 1px solid #ccc;
    background-color: #0000FF;
    -webkit-transition: width 2s, height 2s, background-color 2s, -webkit-transform 2s;
    -moz-transition: width 2s, height 2s, background-color 2s, -moz-transform 2s;
    -o-transition: width 2s, height 2s, background-color 2s, -o-transform 2s;
    transition: width 2s, height 2s, background-color 2s, transform 2s;
    &:hover{
      width: 200px;
      height: 200px;
      background-color: #ffcccc;
      -webkit-transform: rotate(180deg);
      -moz-transform: rotate(180deg);
      -o-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
      transform: rotate(180deg);
    }
  }
}

DEMO 2: 4s 过渡改变字体大小,2s 延迟 

<div class="demo2">show me transition!</div>
.demo2{
  position: relative;
  font-size: 14px;
  -webkit-transition: font-size 4s 2s;
  -moz-transition: font-size 4s 2s;
  -o-transition: font-size 4s 2s;
  transition: font-size 4s 2s;
  &:hover{
    font-size: 36px;
    -webkit-transition: font-size 4s 2s;
    -moz-transition: font-size 4s 2s;
    -o-transition: font-size 4s 2s;
    transition: font-size 4s 2s;
  }
}

DEMO 3: 高亮菜单过渡效果

<div class="demo3">
      <div class="sidebar">
        <p><a class="menuButton" href="home">Home</a></p>
        <p><a class="menuButton" href="about">About</a></p>
        <p><a class="menuButton" href="contact">Contact Us</a></p>
        <p><a class="menuButton" href="links">Links</a></p>
      </div>
</div>
.sidebar{
  display: flex;
  >p:not(:last-child){
    margin-right: 15px;
  }
  .menuButton{
    height: 26px;
    padding: 2px 4px;
    box-shadow: 2px 2px 1px solid;
    border: 1px solid #000;
    font-size: 20px;
    text-align: center;
    text-decoration: none;
    color: #fff;
    background-color: #666;
    -webkit-transition: color 1s ease-out, background-color 1s ease-out;
    -moz-transition: color 1s ease-out, background-color 1s ease-out;
    -o-transition: color 1s ease-out, background-color 1s ease-out;
    transition: color 1s ease-out, background-color 1s ease-out;
    &:hover{
      color: #000;
      background-color: #fff;
      -webkit-transition: color 1s ease-out, background-color 1s ease-out;
      -moz-transition: color 1s ease-out, background-color 1s ease-out;
      -o-transition: color 1s ease-out, background-color 1s ease-out;
      transition: color 1s ease-out, background-color 1s ease-out;
    }
  }
}

转载于:https://www.cnblogs.com/rogerwu/p/9585730.html

内容概要:本文详细探讨了基于MATLAB/SIMULINK的多载波无线通信系统仿真及性能分析,重点研究了以OFDM为代表的多载波技术。文章首先介绍了OFDM的基本原理和系统组成,随后通过仿真平台分析了不同调制方式的抗干扰性能、信道估计算法对系统性能的影响以及同步技术的实现与分析。文中提供了详细的MATLAB代码实现,涵盖OFDM系统的基本仿真、信道估计算法比较、同步算法实现和不同调制方式的性能比较。此外,还讨论了信道特征、OFDM关键技术、信道估计、同步技术和系统级仿真架构,并提出了未来的改进方向,如深度学习增强、混合波形设计和硬件加速方案。; 适合人群:具备无线通信基础知识,尤其是对OFDM技术有一定了解的研究人员和技术人员;从事无线通信系统设计与开发的工程师;高校通信工程专业的高年级本科生和研究生。; 使用场景及目标:①理解OFDM系统的工作原理及其在多径信道环境下的性能表现;②掌握MATLAB/SIMULINK在无线通信系统仿真中的应用;③评估不同调制方式、信道估计算法和同步算法的优劣;④为实际OFDM系统的设计和优化提供理论依据和技术支持。; 其他说明:本文不仅提供了详细的理论分析,还附带了大量的MATLAB代码示例,便于读者动手实践。建议读者在学习过程中结合代码进行调试和实验,以加深对OFDM技术的理解。此外,文中还涉及了一些最新的研究方向和技术趋势,如AI增强和毫米波通信,为读者提供了更广阔的视野。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值