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

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

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

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]刪除
最新教學 更多>
  • 為什麼將 pthread 與 g++ 靜態連結會導致分段錯誤,如何使用「--whole-archive」選項來解決它?
    為什麼將 pthread 與 g++ 靜態連結會導致分段錯誤,如何使用「--whole-archive」選項來解決它?
    當g靜態連結pthread時,導致Segmentation failure,為什麼? 靜態連結時,連結器會停在第一個符號處,甚至如果是弱者,就不再尋找強者。為了強制它查看所有符號(就像對動態連結庫所做的那樣),ld 支援 --whole-archive 選項。 以下指令將起作用:g -o one...
    程式設計 發佈於2024-11-15
  • 構造函數與工廠函數:什麼時候應該使用它們?
    構造函數與工廠函數:什麼時候應該使用它們?
    理解JavaScript 中建構函數與工廠函數的差異在JavaScript 物件建立領域,理解建構函式與工廠函數之間的差異工廠的功能至關重要。這種區別圍繞著底層機制和用於創建新物件的方法。 建構子:的建構子是使用 new 關鍵字呼叫的。此呼叫會觸發 JavaScript 自動建立一個新對象,將函數中...
    程式設計 發佈於2024-11-15
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於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
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-15
  • 如何對儲存為「varbinary(300)」的 MySQL 版本號進行排序?
    如何對儲存為「varbinary(300)」的 MySQL 版本號進行排序?
    MySQL 版本號排序MySQL 版本號排序SELECT version_number FROM table ORDER BY INET_ATON(SUBSTRING_INDEX(CONCAT(version_number,'.0.0.0'),'.',4))修改後的查詢:SELECT versi...
    程式設計 發佈於2024-11-15
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-15
  • **如何在不停用索引的情況下最佳化 InnoDB 中的批次插入? **
    **如何在不停用索引的情況下最佳化 InnoDB 中的批次插入? **
    在InnoDB 中停用InnoDB 中最佳化批次插入的索引在嘗試停用InnoDB 表中的索引以增強批次插入效能時,您可能會遇到由於InnoDB 儲存引擎中缺少此功能而發出警告。以下是實現目標的替代策略:MySQL 參考建議:根據MySQL 文件的建議,考慮使用以下命令: SET 自動提交=0;SET...
    程式設計 發佈於2024-11-15
  • 如何使用命令式方法更新 React 中的巢狀狀態?
    如何使用命令式方法更新 React 中的巢狀狀態?
    更新嵌套狀態的命令式方法在 React 中,狀態更新是不可變的。這意味著要更新嵌套物件或數組,您不能簡單地修改其屬性並期望變更反映在 UI 中。相反,您需要建立包含更新值的新物件或數組,然後將其傳遞給 setState。 考慮以下範例,其中我們要更新物件中索引 1 處的物件的 name 屬性儲存在狀...
    程式設計 發佈於2024-11-14
  • 原子變數有哪些不同的記憶體排序模型?
    原子變數有哪些不同的記憶體排序模型?
    瞭解記憶體排序的意思原子變數提供安全的記憶體存取和跨執行緒同步。了解不同的記憶體順序對於有效利用它們至關重要。 輕鬆:無記憶體同步。 可能重新排序的最佳化操作讀取和寫入。 順序一致 (seq_cst):最嚴格的排序。 防止對周圍的任何記憶體操作進行重新排序原子操作。 確保所有執行緒的記憶體存取一致。...
    程式設計 發佈於2024-11-14
  • 為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    For循環中返回語句錯位在你的作業中,你遇到了一個問題,程式只允許輸入一隻寵物,儘管瞄準三個。這個問題源自於 make_list 函數中 return 語句的定位。 在 for 迴圈中,return 語句在到達函數時立即終止函數的執行。在提供的程式碼中,return 語句放置在循環內部,導致函數在第...
    程式設計 發佈於2024-11-14
  • 如何防止使用者關閉 Bootstrap 模式?
    如何防止使用者關閉 Bootstrap 模式?
    停用使用者啟動的 Bootstrap 模態退出您可以透過點選 Bootstrap 模態區域外部來阻止使用者關閉 Bootstrap 模態。這在您想要強制使用者在繼續操作之前與特定模態內容互動的情況下非常有用。 停用模態背景點擊關閉預設情況下,使用者可以透過點選模式視窗之外的任何位置來關閉模式。若要停...
    程式設計 發佈於2024-11-14
  • 如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    在Python中將嵌套列表匯出到CSV檔案將嵌套列表(其中每個內部列表包含不同類型的元素)寫入CSV檔案可以在Python 中處理資料時這是一項常見任務。以下是應對這項挑戰的方法:Python 的 csv 模組提供了處理 CSV 作業的便利方法。若要將清單的清單(例如a = [[1.2,'a...
    程式設計 發佈於2024-11-14
  • 如何有效率地提取Go Slice的最後一個元素?
    如何有效率地提取Go Slice的最後一個元素?
    Go 提取切片最後一個元素的最佳方法在 Go 中使用切片時,有效操作元素至關重要。一個常見的任務是提取最後一個元素,這可以透過多種方法來實現。 現有解決方案的缺點使用切片提供的解決方案[len(slice)-1 :][0] 看起來很麻煩並且涉及不必要的複雜性。它會傳回一個僅包含最後一個元素的切片,然...
    程式設計 發佈於2024-11-14
  • 為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    動態元素追加後 JavaScript 事件未觸發您遇到了向 DOM 追加新元素後 JavaScript 事件未觸發的問題。這是因為 jQuery 僅識別頁面載入期間最初執行時存在的元素。 要解決此問題,您需要使用事件委託來擷取動態元素中的事件。事件委託涉及擷取頁面載入期間已經存在的 DOM 中較高層...
    程式設計 發佈於2024-11-14

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

Copyright© 2022 湘ICP备2022001581号-3