首頁 >web前端 >js教程 >Radix UI 以自訂調色盤取代 Radix Color

Radix UI 以自訂調色盤取代 Radix Color

Barbara Streisand
Barbara Streisand原創
2024-11-30 00:13:12417瀏覽

在我正在開發的新 Next.js 專案中,我選擇 Tailwind CSSRadix UI 進行樣式設定。 Radix UI 提供了一個自訂調色板工具,讓開發人員可以定義自己的強​​調色和灰色。然而,我搜尋了整個文檔,並沒有找到實現自訂顏色的有效方法。

我開始谷歌搜索,為了救援,我找到了一個部落格來引導我完成任務。以下是我採取的步驟:


步驟 1. 將自訂色階複製並貼上到 global.css 檔案

為「強調色」和「灰色」提供所需顏色的十六進位代碼,然後按一下「複製強調色階」。

Radix UI Replace Radix Color with Custom Palette

將複製的內容貼到 glabal.css 檔案中。

Radix UI Replace Radix Color with Custom Palette

使用複製灰階對灰階進行相同的操作。


第2步.修改tailwind.config.ts中的程式碼

將此程式碼加入文件。如果使用 JavaScript,請使用部落格中的程式碼。我使用 TypeScript,因此在程式碼中添加了一些類型。

function getColorScale(name: string): { [key: string]: string } {
  // eslint-disable-next-line prefer-const
  let scale: { [key: string]: string } = {};
  for (let i = 1; i <= 12; i++) {
    // Add the color variable to the scale
    scale[i.toString()] = `var(--${name}-${i})`;
    // Add alpha color variable to the scale
    scale[`a${i}`] = `var(--${name}-a${i})`;
  }

  return scale;
}

此程式碼從 global.css 檔案取得顏色比例,並將其轉換為 tailwind css 自訂顏色時所採用的格式。

接下來,修改主體物件下的顏色物件。

在此範例中,強調色階的顏色類別為藍色,因此在呼叫 getColorScale 時只需將藍色作為參數即可。

Radix UI Replace Radix Color with Custom Palette

對灰色進行同樣的操作。

theme: {
    extend: {
      colors: {
        accent: getColorScale("blue"),
        gray: getColorScale("gray")
      }
    }
  },

第3步.更新layout.tsx檔

預設情況下,accentColor 設定為藍色,grayColor 設定為灰色,因此在本例中,色階將自動更新,但如果顏色類別是不同的顏色,例如橙色,那麼您需要將accentColor更新為橙色。

<Theme accentColor='blue' grayColor='gray'>
  <NavBar />
  <main>{children}</main>
  <Footer />
</Theme>

由於重新定義了藍色的色標,Radix UI 中的任何主題元件現在都將使用自訂色標來設定元件的樣式。


這就是我在網站上應用自訂色階而無需重新定義每個元件的方法。

如何客製化您的?

以上是Radix UI 以自訂調色盤取代 Radix Color的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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