」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 讓每一秒都有一個主題! ⏰ 使用 @property 和 hsl()

讓每一秒都有一個主題! ⏰ 使用 @property 和 hsl()

發佈於2024-11-04
瀏覽:230

Make Every Second have a Theme! ⏰ using @property and hsl()

?介紹

您是否曾經想過創建一個不僅僅是報時的時鐘?如果每一秒都會帶來一個全新的主題呢?借助 CSS @property 和 hsl() 顏色操作的強大功能,您可以!在本文中,我將引導您完成一個動態且具有視覺吸引力的「主題時鐘」的創建過程,該時鐘每秒都會改變其顏色(又稱其主題),為每個時刻帶來新的生命! .


?️ 概念

「主題時鐘」背後的想法簡單而迷人:隨著時間的流逝,時鐘的外觀會改變。我們將利用 CSS 自訂屬性來動畫顏色的色調(嗯,這是以度為單位的角度)並每秒更新時鐘的主題(也每分鐘和每小時)。結果呢?一個無縫、不斷變化的時鐘,既迷人又實用。


?演示和程式碼

嗯,這是「主題時鐘」的完整代碼。我將對其進行分解,以了解每個部分如何對整體效果做出貢獻。

?分解代碼

1.CSS自訂屬性與@property:這個主題變換時鐘背後的魔力在於CSS自訂屬性和@property規則的使用。我們定義一個自訂屬性 --angle,它使用 hsl() 函數來控制時鐘顏色的色調。透過使用 @keyframes 規則對該屬性進行 60 秒的動畫處理,我們實現了連續的顏色過渡。

  • 自訂屬性--angle:控制hsl()顏色的色調,動態改變主題。並且還使自訂屬性可設定動畫,從而實現平滑過渡。
  • CSS @keyframes anim:此動畫在 60 秒內將色調值從 0 旋轉到 360,循環遍歷整個色譜。

2.動態主題切換:切換按鈕可讓使用者在淺色和深色主題之間切換。點擊按鈕會在 html 元素上切換深色類,從而改變時鐘的外觀。

  • 亮/暗模式切換:可以使用動態更新時鐘外觀的按鈕切換主題。
  • 容器旋轉動畫:主題變化時時鐘容器旋轉,加入微妙的過渡效果。

3.時鐘與時間更新:程式碼的 JavaScript 部分處理時鐘指標和數位時間顯示的更新。 setTime 函數每秒重新計算時針、分針和秒針的位置,同時也更新時間和日期顯示。

  • "scale" 功能:將目前時間轉換為對應鐘針旋轉的度數。

- 即時更新:時鐘指針和數位時間每秒更新以匹配當前時間。

?將所有部分組合在一起

透過結合 CSS 自訂屬性、hsl() 色彩操作和 @property 規則的強大功能,我們創建了一個時鐘,它不僅可以顯示時間,而且其外觀也會隨著每一秒的流逝而變化。這個專案就是一個很好的例子,說明如何使用 CSS 以最少的 JavaScript 建立互動式且具有視覺吸引力的 Web 元素。


按讚❤️,關注更多alishata128

版本聲明 本文轉載於:https://dev.to/alishata128/make-every-second-have-a-theme-using-property-and-hsl-4n55?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • PowerPC 錯誤安裝後如何在 Mac OS X 上完全解除安裝 MySQL?
    PowerPC 錯誤安裝後如何在 Mac OS X 上完全解除安裝 MySQL?
    從Mac OS X 卸載MySQL:解決不正確的PowerPC 安裝試圖糾正Intel- 上MySQL PowerPC 版本的錯誤安裝一位使用者在執行Snow Leopard 的Mac 上嘗試安裝正確的x86 版本時遇到了安裝衝突。儘管按照說明進行了手動卸載,但問題仍然存在,無法成功安裝。 要解決此...
    程式設計 發佈於2024-11-15
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-15
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-15
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-15
  • 為什麼 MySQL 查詢結果在 PHP 中以字串形式傳回?
    為什麼 MySQL 查詢結果在 PHP 中以字串形式傳回?
    Retriving MySQL Query Results in Native Data Types這個問題圍繞著使用時獲取本地資料類型的 MySQL 查詢結果的問題PHP。具體來說,儘管使用 mysql_fetch_row() 和 mysql_result(),開發人員仍會遇到以字串形式傳回數值的...
    程式設計 發佈於2024-11-15
  • 如何在 JavaScript 中有效率地檢查素數?
    如何在 JavaScript 中有效率地檢查素數?
    如何在 JavaScript 中確定質數在 JavaScript 中,辨識素數是一項常見的程式設計任務。質數是大於 1 的正整數,除了 1 和它本身之外,不能被任何其他正整數整除。 解決方案1:Naive Approach提供的代碼代碼片段提供了檢查數字是否為素數的簡單方法:let inputVal...
    程式設計 發佈於2024-11-15
  • 如何在Go中解析具有特定時區的時間字串?
    如何在Go中解析具有特定時區的時間字串?
    解析特定時區的時間您可以使用 time.ParseTime() 從字串中取得時間結構。它採用佈局字串作為參數,指定輸入字串的格式。佈局字串必須與輸入字串的格式完全相符。 如果需要解析包含時區的時間字串,可以使用 time.ParseInLocation()。此函數採用佈局字串和位置作為參數。該位置可...
    程式設計 發佈於2024-11-15
  • 執行 Python 腳本時如何處理 Windows 中的命令列參數?
    執行 Python 腳本時如何處理 Windows 中的命令列參數?
    Windows 中的Python 腳本執行:了解參數處理在Windows 中,執行Python 腳本而不在指令中指定「python」可能會導致意外的行為。此問題源自於 Windows 將檔案類型與執行檔關聯的方式。 當不使用「python」執行腳本時,Windows 會根據檔案副檔名呼叫關聯的 EX...
    程式設計 發佈於2024-11-15
  • 使用「justify-content: space-around」時,為什麼 Flex 容器專案居中對齊而不是左對齊?
    使用「justify-content: space-around」時,為什麼 Flex 容器專案居中對齊而不是左對齊?
    Flex 容器項目左對齊在行動選單中,使用 Flexbox 排列社群媒體圖示清單。為了確保相等的間距,請使用 justify-content: space-around 。但是,當行包含三個以上的項目時,它們會居中對齊而不是左對齊。 困境出現問題的原因是 justify-content: space...
    程式設計 發佈於2024-11-15
  • 如何正確使用 canvas.toDataURL() 將 Canvas 輸出擷取為影像?
    如何正確使用 canvas.toDataURL() 將 Canvas 輸出擷取為影像?
    擷取畫布輸出為影像:使用canvas.toDataURL() 解決挑戰開發HTML5 應用程式時,擷取畫布的內容作為影像可能是一項重要任務。 canvas.toDataURL() 方法提供了實現此目的的方法,但有時其實作可能會遇到障礙。 常見陷阱canvas 遇到的一個常見問題。 toDataURL...
    程式設計 發佈於2024-11-15
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-15
  • 我可以在 Chrome 和 Firefox 中使用 CSS 設定 JavaScript 控制台訊息的樣式嗎?
    我可以在 Chrome 和 Firefox 中使用 CSS 設定 JavaScript 控制台訊息的樣式嗎?
    在Chrome 和Firefox 中設計JavaScript 控制台的樣式在當今的Web 開發領域,JavaScript 控制台已成為調試錯誤不可或缺少的工具並顯示資訊。然而,當嘗試區分不同類型的訊息時,標準單色輸出可能會受到限制。這個問題解決了一個常見問題:JavaScript 控制台能否顯示顏色...
    程式設計 發佈於2024-11-15
  • 如何在 JavaScript 中轉義正規表示式特殊字元?
    如何在 JavaScript 中轉義正規表示式特殊字元?
    如何在JavaScript 中轉義正則表達式特殊字元轉義正則表達式特殊字元對於實現模式匹配的精確度至關重要。若要在 JavaScript 中執行此操作,您可以使用 \ 字元作為正規表示式中具有特殊意義的字元的前綴。 例如,如果您想要配對文字 [,則需要將其轉義為 \[ 。然而,為了自動化這個過程,使...
    程式設計 發佈於2024-11-15
  • 為什麼我的 PHP 檔案上傳驗證程式碼無法正常運作?
    為什麼我的 PHP 檔案上傳驗證程式碼無法正常運作?
    PHP 檔案上傳:確保檔案類型和大小限制在 PHP 中,處理檔案上傳通常需要驗證檔案類型和大小限制。提供的程式碼片段嘗試驗證這兩個標準,但遇到了問題。讓我們深入研究程式碼並找出錯誤。 //check file extension and size $resume = ($_FILES['resume...
    程式設計 發佈於2024-11-15
  • 儘管使用 32 位,為什麼 C 和 Java 的整數具有不同的範圍?
    儘管使用 32 位,為什麼 C 和 Java 的整數具有不同的範圍?
    了解C 和Java 中的整數範圍差異雖然C 和Java 都為其整數資料型別指定了32 位元表示形式,但它們的變體由於數據處理方面的根本差異,它們存在於其實際範圍內。 C 的機器相關整數表示在 C 中,整數的大小和範圍沒有明確定義語言,允許依賴機器的變化。傳統上,在32 位元機器上,整數佔用32 位,...
    程式設計 發佈於2024-11-15

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3