首頁 >web前端 >前端問答 >css3中用什麼來定義過渡動畫的時間

css3中用什麼來定義過渡動畫的時間

青灯夜游
青灯夜游原創
2022-02-28 13:35:375126瀏覽

在css3中,可以使用transition-duration屬性來定義過渡動畫的時間,該屬性可以規定完成過渡效果所需花費的時間(以秒或毫秒計),設定語法為「transition-duration: time;」。

css3中用什麼來定義過渡動畫的時間

本教學操作環境:windows7系統、CSS3&&HTML5版、Dell G3電腦。

在css3中,可以使用transition-duration屬性來定義過渡動畫的時間。

過渡簡介

transition呈現的是一種過渡,是一種動畫轉換的過程,如漸進、漸弱、動畫快慢等。

CSS3 transition的過渡功能更像是一種“黃油”,透過一些CSS的簡單動作觸發樣式平滑過渡。

1.過渡屬性(transition-property) 定義轉換動畫的CSS屬性名稱

IDENT:指定的CSS屬性(width、height、background-color屬性等)

all:指定所有元素支援transition-property屬性的樣式,一般為了方便都會使用all

2.過渡所需的時間(transition-duration) 定義轉換動畫的時間長度

即從設定舊屬性到換新屬性所花費的時間,單位為秒(s)

3.過渡動畫函數( transition-timing -function )

指定瀏覽器的過渡速度,以及過渡期間的操作進展情況,透過向過渡添加一個函數來指定動畫的快慢方式

常見的過渡動畫
ease:速度由快到慢(預設值)
linear :速度恆速(勻速運動)
ease-in:速度越來越快(漸顯效果)
ease-out:速度越來越慢(漸隱效果)
ease-in-out:速度先加速再減速(漸顯漸隱效果)

#4.過渡延遲時間( transition-delay )

  • #指定一個動畫開始執行的時間,當改變元素屬性值後多長時間去執行過渡效果

  • 正值:元素過渡效果不會立即觸發,當過了設定的時間值後才會被觸發

  • 負值:元素過渡效果會從該時間點開始顯示,先前的動作被截斷

  • 0:預設值,元素過渡效果立即執行

#
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>transition-property的使用</title>
    <style>
        div{
            background-color: red;
            width: 200px;
            height: 200px;
            /*指定动画过渡的CSS属性 过渡时间 过渡动画 延迟时间*/
            transition:  background-color 2s ease-in-out 3s;
            -moz-transition:  background-color 2s ease-in-out 3s;
            -webkit-transition:  background-color 2s ease-in-out 3s;
            -o-transition:  background-color 2s ease-in-out 3s;
        }
        div:hover{
            background-color: yellow;

        }
    </style>
</head>
<body>
    <div></div>
</body>
</html>

過渡的觸發機制

如果沒有滑鼠移入的效果去觸發過渡,其實div是不會發生任何變化的。偽類hover是觸發過渡機制的一種。還有哪些觸發方法呢?

  • 偽類別觸發::hover、:active、:focus、checked等。

  • 媒體查詢:透過@media屬性判斷裝置的尺寸,方向等。

  • JavaScript觸發:用JavaScript腳本觸發。

以下總結transition實作過渡動畫的使用步驟:

(1)在預設樣式中宣告元素的初始狀態樣式。

(2)宣告過渡元素最終狀態樣式,如懸浮狀態。

(3)在預設樣式中透過新增過渡函數,加入一些不同的樣式。

(學習影片分享:css影片教學web前端入門教學

以上是css3中用什麼來定義過渡動畫的時間的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn