成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

TypeScript封裝一個根據背景色顯示適合的字體顏色

開發 前端
在TypeScript中,你可以創建一個函數來確定基于背景顏色的對比色(通常是黑色或白色)作為文本顏色,以確保文本的可讀性。

方法一

在TypeScript中,你可以創建一個函數來確定基于背景顏色的對比色(通常是黑色或白色)作為文本顏色,以確保文本的可讀性。為了計算背景顏色與黑白之間的對比度,我們可以使用Web內容可訪問性指南(WCAG)的公式。

下面是一個簡單的TypeScript函數示例,它接受一個背景顏色(十六進制格式)作為輸入,然后返回一個推薦的字體顏色(黑色或白色):

function getContrastYIQ(hexcolor: string): string {
  // 如果輸入不帶#,則添加
  if (hexcolor.indexOf('#') !== 0) {
    hexcolor = '#' + hexcolor;
  }

  // 去除#號
  hexcolor = hexcolor.replace('#', '');

  // 將十六進制顏色分解為r, g, b
  const r = parseInt(hexcolor.substr(0, 2), 16);
  const g = parseInt(hexcolor.substr(2, 2), 16);
  const b = parseInt(hexcolor.substr(4, 2), 16);

  // 使用YIQ方程式計算亮度
  const yiq = ((r * 299) + (g * 587) + (b * 114)) / 1000;

  // 根據亮度返回黑色或白色
  return yiq >= 128 ? 'black' : 'white';
}

// 用法示例
const backgroundColor = '#005A31'; // 深綠色
const textColor = getContrastYIQ(backgroundColor);
console.log(textColor); // 應該返回'white'因為深綠色背景下白色文本更可讀

這個函數使用了YIQ色彩空間,這是一個電視廣播領域使用的色彩空間,其中Y代表亮度分量,而I和Q分別代表色度分量。在這個例子中,我們只關心Y分量(亮度),以決定文本顏色使用黑色還是白色。

請確保輸入的顏色格式正確,并且你的應用可以處理不同的輸入格式。上面的代碼假設輸入是一個六位的十六進制顏色值。

此外,還有更復雜的方法來判斷對比度,比如根據WCAG 2.0標準計算顏色之間的對比度比率。這樣的計算會更復雜一些,但也可以提供更精確的結果。

方法二

如果你希望函數能夠返回除黑白之外的其他顏色作為字體顏色,你可以通過定義一組顏色和它們的亮度閾值來實現。這樣,函數就可以根據背景顏色的亮度來選擇一個合適的字體顏色。

首先,我們定義一個簡單的亮度判斷函數,然后基于背景色的亮度選擇合適的字體顏色。這里舉例說明如何擴展前面的函數以支持多種顏色選擇。

function getBrightness(hexcolor: string): number {
  // 標準化十六進制格式
  if (!hexcolor.startsWith('#')) {
    hexcolor = '#' + hexcolor;
  }

  // 提取RGB組件
  const r = parseInt(hexcolor.substring(1, 3), 16);
  const g = parseInt(hexcolor.substring(3, 5), 16);
  const b = parseInt(hexcolor.substring(5, 7), 16);

  // 計算亮度
  return ((r * 299) + (g * 587) + (b * 114)) / 1000;
}

function chooseTextColor(backgroundHex: string): string {
  // 定義顏色選項和它們的亮度界限
  const colors = [
    { color: '#000000', minBrightness: 0, maxBrightness: 180 },   // 黑色
    { color: '#FFFFFF', minBrightness: 180, maxBrightness: 256 }, // 白色
    { color: '#FFD700', minBrightness: 100, maxBrightness: 220 }, // 金色
    { color: '#0000FF', minBrightness: 50, maxBrightness: 150 }   // 藍色
  ];

  // 獲取背景色亮度
  const backgroundBrightness = getBrightness(backgroundHex);

  // 選擇一個亮度合適的顏色
  const suitableColor = colors.find(c => backgroundBrightness >= c.minBrightness && backgroundBrightness < c.maxBrightness);
  return suitableColor ? suitableColor.color : '#FFFFFF'; // 默認返回白色
}

// 用法示例
const backgroundColor = '#005A31'; // 深綠色
const textColor = chooseTextColor(backgroundColor);
console.log(textColor); // 根據配置,可能返回不同顏色

在這個例子中,我為函數增加了幾種顏色選擇。函數chooseTextColor將檢查背景顏色的亮度,并找到一個在設定亮度范圍內的顏色作為文本顏色。你可以根據需要調整顏色選項和它們的亮度界限。

責任編輯:姜華 來源: 今日頭條
相關推薦

2022-12-26 11:25:25

CSS黑白文字

2024-01-30 13:53:31

2021-04-16 05:54:05

CSS 文字動畫技巧

2010-08-11 16:41:30

Flex DataGr

2010-08-11 16:30:49

Flex DataGr

2023-11-09 09:02:26

TypeScriptas const

2015-06-08 11:21:42

iOS技巧

2024-04-02 09:42:39

2013-08-27 14:03:33

Web設計設計字體

2024-04-09 07:36:03

AI產品AI技術人工智能

2024-01-26 12:35:25

JavaScript項目軟件包

2015-09-08 10:32:21

開源項目選擇方式

2015-09-11 10:29:13

開源項目閱讀

2020-06-18 10:03:13

在家工作疫情統一通信

2024-04-07 00:00:01

TypeScript語言REST

2018-11-29 09:45:03

Windows 10Windows版本

2023-10-08 11:53:29

2020-06-17 15:00:27

FedoraUbuntuLinux

2022-11-21 07:57:56

cmake工程模板

2023-07-17 09:19:20

CSSCSS 漸變
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲成人一区二区三区 | 久热久热 | 中文在线一区 | 国产成人精品一区二区三区 | 日韩在线精品视频 | 久草青青草 | 精品真实国产乱文在线 | 久久日韩粉嫩一区二区三区 | 国产电影一区二区在线观看 | 欧美一级二级视频 | 91中文| 久久人人爽人人爽 | 亚洲乱码一区二区三区在线观看 | 天堂免费 | 久久黄色精品视频 | 亚洲毛片一区二区 | 久草.com | 欧美精品三区 | 在线免费激情视频 | 北条麻妃av一区二区三区 | 国产日韩精品在线 | 高清黄色| www国产成人免费观看视频,深夜成人网 | 欧美一区二区三区国产精品 | 久久久久久久91 | 超碰导航| 美女黄网站 | 99riav国产一区二区三区 | 精品1区| 欧美一区二区免费在线 | 盗摄精品av一区二区三区 | 免费午夜电影 | 久久亚洲欧美日韩精品专区 | 久久夜视频 | 欧美久久精品一级c片 | 成人福利视频网站 | www一级片 | 在线观看午夜视频 | 日韩av手机在线观看 | 精品国产99| 中文字幕91 |