【面试题】CSS transition 属性全面详解

摘要:transition 属性是一个简写属性,用于设置四个过渡属性:transition-property 规定设置过渡效果的 CSS 属性的名称。transition-duration 规定完成过渡效果需要多少秒或毫秒。transition-timing-function 规定速度效果的速度曲线。

CSS transition 属性

定义和用法

transition 属性是一个简写属性,用于设置四个过渡属性:

  • transition-property 规定设置过渡效果的 CSS 属性的名称。
  • transition-duration 规定完成过渡效果需要多少秒或毫秒。
  • transition-timing-function 规定速度效果的速度曲线。
  • transition-delay 定义过渡效果何时开始。

默认值: all 0 ease 0

注释:请始终设置 transition-duration 属性,否则时长为 0,就不会产生过渡效果。

transition-property 属性

定义和用法

transition-property 属性规定应用过渡效果的 CSS 属性的名称。(当指定的 CSS 属性改变时,过渡效果将开始)。

语法:transition-property: none|all|property;

默认值: all

描述
none没有属性会获得过渡效果。
all所有属性都将获得过渡效果。
property定义应用过渡效果的 CSS 属性名称列表,列表以逗号分隔。

案例:

<template>
  <div id="app">
    <div></div>
    <p>请把鼠标指针移动到蓝色的 div 元素上,就可以看到过渡效果。</p>
  </div>
</template>

<script>
export default {
  name: 'App',
  data(){
    return {
      
    } 
  },
  mounted() {
    
  },
  methods:{
    
  }
}
</script>

<style scoped>
.demo{
  width:100px;
  height:100px;
  background:blue;
  transition-property: width;
  transition-duration: 2s;
}

.demo:hover{
  width:300px;
}
</style>

transition-duration 属性

定义和用法

transition-duration 属性规定完成过渡效果需要花费的时间(以秒或毫秒计)。

语法:transition-duration: time;

默认值: 0

描述
time规定完成过渡效果需要花费的时间(以秒或毫秒计)。默认值是 0,意味着不会有效果。

案例:

<template>
  <div id="app">
    <div></div>
    <p>请把鼠标指针移动到蓝色的 div 元素上,就可以看到过渡效果。</p>
  </div>
</template>

<script>
export default {
  name: 'App',
  data(){
    return {
      
    } 
  },
  mounted() {
    
  },
  methods:{
    
  }
}
</script>

<style scoped>
.demo{
  width:100px;
  height:100px;
  background:blue;
  transition-property: width;
  transition-duration: 5s;
}

.demo:hover{
  width:300px;
}
</style>

transition-timing-function 属性

定义和用法

transition-timing-function 属性规定过渡效果的速度曲线。

该属性允许过渡效果随着时间来改变其速度。

语法:transition-timing-function: linear|ease|ease-in|ease-out|ease-in-out|cubic-
bezier(n,n,n,n);

默认值: ease

描述
linear规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1))
ease规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0.25,0.1,0.25,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(n,n,n,n)在 cubic-bezier 函数中定义自己的值。可能的值是 0 至 1 之间的数值

案例:

<template>
  <div id="app">
    <div></div>
    <p>请把鼠标指针移动到蓝色的 div 元素上,就可以看到过渡效果。</p>
  </div>
</template>

<script>
export default {
  name: 'App',
  data(){
    return {
      
    } 
  },
  mounted() {
    
  },
  methods:{
    
  }
}
</script>

<style scoped>
.demo{
  width:100px;
  height:100px;
  background:blue;
  transition:width 5s;
  transition-timing-function:linear;
}

.demo:hover{
  width:300px;
}
</style>

transition-delay 属性

定义和用法

transition-delay 属性规定过渡效果何时开始。

transition-delay 值以秒或毫秒计。

语法:transition-delay: time;

默认值: 0

描述
time规定在过渡效果开始之前需要等待的时间,以秒或毫秒计。

案例:

<template>
  <div id="app">
    <div></div>
    <p>请把鼠标指针移动到蓝色的 div 元素上,就可以看到过渡效果。</p>
  </div>
</template>

<script>
export default {
  name: 'App',
  data(){
    return {
      
    } 
  },
  mounted() {
    
  },
  methods:{
    
  }
}
</script>

<style scoped>
.demo{
  width:100px;
  height:100px;
  background:blue;
  transition-property:width;
  transition-duration:5s;
  transition-delay:2s;
}

.demo:hover{
  width:300px;
}
</style>

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_12015