」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 Tailwind CSS 創作流星邊框動畫

使用 Tailwind CSS 創作流星邊框動畫

發佈於2024-09-15
瀏覽:344

Creating a Shooting Star Border Animation with Tailwind CSS

在這篇文章中,我們將使用 Tailwind CSS 創建一個迷人的「流星」邊框動畫。此效果為輸入欄位提供發光的動畫邊框,可吸引使用者的注意力,非常適合電子郵件註冊或重要通知等號召性用語部分。

示範

在深入程式碼之前,您可以在此處查看效果的現場演示:在 Tailwind Playground 中查看。

概念

動畫是使用 Tailwind CSS 的實用程式類別和偽元素實現的。我們將使用 Tailwind 的 after 偽類來創建圍繞輸入字段旋轉的圓錐漸變動畫,給人一種流星追蹤邊界的錯覺。

HTML 和 Tailwind CSS 設定

以下是建立此效果所需的 HTML 結構和 Tailwind CSS 類別:

分解代碼

容器設定

  
  • 我們首先創建一個 Flex 容器,以 h-screen(全高)和 bg-black(黑色背景)垂直和水平居中內容。

輸入欄位的包裝

  
  • 輸入欄位被包裝在一個div 中,該div 具有z-10 以確保其位於動畫邊框上方,m-auto 將其在Flex 容器中居中,以及Overflow-hidden 以將動畫邊框包含在其邊界內。

帶有動畫邊框的輸入字段

  
  • 主輸入欄位設定為固定寬度 500px,高度為 14 Tailwind 單位。
  • border-white/50 類別添加半透明邊框,而 rounded-md 類別則為其提供圓角。
  • bg-black 將背景顏色設為黑色,將其與容器混合。

創作動畫

  after:absolute after:-inset-[1px] after:-z-10 after:h-full after:w-full after:animate-[spin_4s_infinite] after:bg-[conic-gradient(var(--tw-gradient-stops))] after:from-transparent after:from-40% after:via-50% after:to-blue-600 after:to-100%">
  • after 偽元素用於創建圍繞邊框進行動畫處理的圓錐漸變。
  • after:-inset-[1px] 稍微將漸變擴展到輸入邊界之外,而 after:absolute 將其絕對定位以覆蓋整個輸入區域。
  • after:animate-[spin_4s_infinite] 新增一個自訂旋轉動畫,每 4 秒完成一次完整旋轉。
  • after:bg-[conic-gradient...] 建立漸變效果。我們使用 from-transparent 和 to-blue-600 類別來定義色標,從而提供模仿流星的褪色效果。

輸入欄位樣式

  
  • 輸入本身是透明的(背景透明)並佔據其父級的整個高度和寬度。
  • text-lg 類別調整文字大小,而 text-white 和 placeholder:text-white/40 確保文字和占位符在深色背景下可見。
  • 最後,focus:outline-none 刪除預設的焦點輪廓以保持自訂樣式。

結論

只需幾行 Tailwind CSS 和偽元素的強大功能,您就可以創建像流星邊框動畫這樣引人注目的效果。這種效果不僅美觀,而且易於實現並為您自己的專案進行客製化。請隨意調整顏色、時間和其他屬性以滿足您的設計需求!

編碼愉快!

Unsplash 上的封面照片由 Juskteez Vu 拍攝

版本聲明 本文轉載於:https://dev.to/rawjson/creating-a-shooting-star-border-animation-with-tailwind-css-1hf7?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何將參數傳遞給使用「chrome.tabs.executeScript()」注入的內容腳本?
    如何將參數傳遞給使用「chrome.tabs.executeScript()」注入的內容腳本?
    將參數傳遞給使用chrome.tabs.executeScript() 注入的內容腳本使用chrome.tabs.executeScript 注入內容腳本文件時({file: "content.js"}),出現一個常見問題:如何在內容腳本檔案中向JavaScript 傳遞參數? ...
    程式設計 發佈於2024-11-07
  • 自訂 Django 面板:逐步指南
    自訂 Django 面板:逐步指南
    在本指南中,我將引導您了解如何修改和擴展 Django 預設管理面板/介面,使其更加用戶友好。 1.設定項目: 首先在 Django 中創建一個全新的專案和應用程式 django-admin startproject myprojectname cd myprojectname python ma...
    程式設計 發佈於2024-11-07
  • 了解身分驗證流程
    了解身分驗證流程
    什麼是身分驗證流程? 身分驗證流程是確認使用者身分並管理他們對應用程式某些部分的存取的過程。當您使用網路應用程式(例如社交媒體網站)時,這涉及檢查使用者是否是他們所說的人(登入),然後授予他們存取某些功能的權限。 它在 React 中是如何運作的? 在 React...
    程式設計 發佈於2024-11-07
  • 如何使用 mysqli_pconnect() 在 PHP 中實作 MySQL 連線池?
    如何使用 mysqli_pconnect() 在 PHP 中實作 MySQL 連線池?
    MySQL 的 PHP 連線池在 PHP 中,維護資料庫連線會影響效能。為了優化這一點,開發人員經常考慮使用連接池技術。 MySQL 的連線池MySQL 沒有內建的連線池機制。然而,MySQLi 擴充功能提供了mysqli_pconnect() 函數,其作用與mysqli_connect() 類似,...
    程式設計 發佈於2024-11-07
  • 將 HTMX 加入 GO
    將 HTMX 加入 GO
    HTMX 是 intercooler.js 的後繼者,用於使用 HTTP 指令擴充 HTML,而無需編寫 API。現在,我知道一開始我說我要刪除抽象層,但是我更多的是系統/工具程式設計師,所以我仍然需要一些抽象,直到我掌握了底層實際發生的情況。 基本概念 HTMX 部署 AJAX ...
    程式設計 發佈於2024-11-07
  • 發現 itertools
    發現 itertools
    Itertools 是最有趣的 Python 函式庫之一。它包含一系列受函數式語言啟發的函數,用於與迭代器一起使用。 在這篇文章中,我將提到一些最引起我注意並且值得牢記的內容,以免每次都重新發明輪子。 數數 好幾次我都實現了無限數(好吧,結束了 明確地在某一點用中斷)使用 whi...
    程式設計 發佈於2024-11-07
  • 為什麼每個人都應該學習 Go(即使您認為生活中不需要另一種語言)
    為什麼每個人都應該學習 Go(即使您認為生活中不需要另一種語言)
    啊,Go,编程语言。您可能听说过,也许是从办公室里一位过于热情的开发人员那里听说过的,他总是不停地谈论他们的 API 现在有多“快得惊人”。当然,您已经涉足过其他语言,也许您会想:“我真的需要另一种语言吗?”剧透警报:是的,是的,你知道。 Go 就是那种语言。让我以最讽刺、最真诚的方式为你解释一下。...
    程式設計 發佈於2024-11-07
  • 如何計算 Pandas 中多列的最大值?
    如何計算 Pandas 中多列的最大值?
    在Pandas 中尋找多列的最大值假設您有一個包含多列的資料框,並且希望建立一個包含兩個或多個列中的最大值的新列現有的列。例如,給定A 列和B 列,您需要建立C 列,其中:C = max(A, B)要完成此任務:使用max 函數和axis=1 計算指定列中每行的最大值:df[["A&quo...
    程式設計 發佈於2024-11-07
  • 如何在 PHP 中從目錄中檢索檔案名稱?
    如何在 PHP 中從目錄中檢索檔案名稱?
    從 PHP 中的目錄中擷取檔案如何在 PHP 中存取目錄中的檔案名稱?事實證明,確定正確的命令具有挑戰性。這個問題旨在為尋求類似解決方案的個人提供幫助。 PHP提供了幾種從目錄獲取文件清單的方法:DirectoryIterator(建議)此類允許對目錄中的文件進行迭代:foreach (new Di...
    程式設計 發佈於2024-11-07
  • 使用 Linq、Criteria API 和 Query Over 擴充 NHibernate 的 Ardalis.Specification
    使用 Linq、Criteria API 和 Query Over 擴充 NHibernate 的 Ardalis.Specification
    Ardalis.Specification is a powerful library that enables the specification pattern for querying databases, primarily designed for Entity Framework Cor...
    程式設計 發佈於2024-11-07
  • PYTHON:OOP {初學者版}
    PYTHON:OOP {初學者版}
    Python:物件導向程式設計[OOP]:是一種程式設計範式(模型),使用物件和類別來建立軟體一種模擬現實世界實體和關係的方法。這是基於物件可以包含資料和操作該資料的程式碼的想法。 關於物件導向編程,您需要了解一些關鍵概念: 班級 目的 屬性 方法 遺產 封裝 多態性 抽象 下面的範例是一個幫助您...
    程式設計 發佈於2024-11-07
  • Neo.mjs:一個高效能開源 JavaScript 框架。
    Neo.mjs:一個高效能開源 JavaScript 框架。
    在瀏覽 GitHub 並尋找可協作的開源專案時,我發現了 Neo.mjs。我對這個計畫產生了興趣,並開始更多地研究這個新框架。我想在這篇文章中分享我發現的所有內容。 什麼是 Neo.mjs? Neo.mjs 旨在建立高效能、資料驅動的 Web 應用程序,重點在於利用 Web Wor...
    程式設計 發佈於2024-11-07
  • 將 Azure Functions 部署到 Azure 容器應用程式的兩種方法的比較
    將 Azure Functions 部署到 Azure 容器應用程式的兩種方法的比較
    昨天,我寫了一篇題為「在 Azure 容器應用程式上部署 Java Azure Function」的文章。 在那篇文章中,我提到使用 Azure 的整合管理功能,我想澄清這意味著什麼以及它與本文中先前的方法有何不同。 舊方法:使用 az containerapp create 創...
    程式設計 發佈於2024-11-07
  • 如何使用 MinGW 在 Windows 上建置 GLEW?逐步指南。
    如何使用 MinGW 在 Windows 上建置 GLEW?逐步指南。
    使用MinGW 在Windows 上建立GLEW:綜合指南使用GLEW,這是一個無縫整合OpenGL 和WGL 函數的純頭文件庫,使用MinGW 增強Windows 上OpenGL 應用程式的開發。為了使用 MinGW 有效建置 GLEW,需要一組特定的命令和步驟。 首先,建立兩個名為 lib 和 ...
    程式設計 發佈於2024-11-07

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

Copyright© 2022 湘ICP备2022001581号-3