日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

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

來源: 責(zé)編: 時間:2024-05-08 09:16:19 162觀看
導(dǎo)讀方法一在TypeScript中,你可以創(chuàng)建一個函數(shù)來確定基于背景顏色的對比色(通常是黑色或白色)作為文本顏色,以確保文本的可讀性。為了計算背景顏色與黑白之間的對比度,我們可以使用Web內(nèi)容可訪問性指南(WCAG)的公式。下面是一個

if428資訊網(wǎng)——每日最新資訊28at.com

方法一

在TypeScript中,你可以創(chuàng)建一個函數(shù)來確定基于背景顏色的對比色(通常是黑色或白色)作為文本顏色,以確保文本的可讀性。為了計算背景顏色與黑白之間的對比度,我們可以使用Web內(nèi)容可訪問性指南(WCAG)的公式。if428資訊網(wǎng)——每日最新資訊28at.com

下面是一個簡單的TypeScript函數(shù)示例,它接受一個背景顏色(十六進(jìn)制格式)作為輸入,然后返回一個推薦的字體顏色(黑色或白色):if428資訊網(wǎng)——每日最新資訊28at.com

function getContrastYIQ(hexcolor: string): string {  // 如果輸入不帶#,則添加  if (hexcolor.indexOf('#') !== 0) {    hexcolor = '#' + hexcolor;  }  // 去除#號  hexcolor = hexcolor.replace('#', '');  // 將十六進(jìn)制顏色分解為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;  // 根據(jù)亮度返回黑色或白色  return yiq >= 128 ? 'black' : 'white';}// 用法示例const backgroundColor = '#005A31'; // 深綠色const textColor = getContrastYIQ(backgroundColor);console.log(textColor); // 應(yīng)該返回'white'因為深綠色背景下白色文本更可讀

這個函數(shù)使用了YIQ色彩空間,這是一個電視廣播領(lǐng)域使用的色彩空間,其中Y代表亮度分量,而I和Q分別代表色度分量。在這個例子中,我們只關(guān)心Y分量(亮度),以決定文本顏色使用黑色還是白色。if428資訊網(wǎng)——每日最新資訊28at.com

請確保輸入的顏色格式正確,并且你的應(yīng)用可以處理不同的輸入格式。上面的代碼假設(shè)輸入是一個六位的十六進(jìn)制顏色值。if428資訊網(wǎng)——每日最新資訊28at.com

此外,還有更復(fù)雜的方法來判斷對比度,比如根據(jù)WCAG 2.0標(biāo)準(zhǔn)計算顏色之間的對比度比率。這樣的計算會更復(fù)雜一些,但也可以提供更精確的結(jié)果。if428資訊網(wǎng)——每日最新資訊28at.com

方法二

如果你希望函數(shù)能夠返回除黑白之外的其他顏色作為字體顏色,你可以通過定義一組顏色和它們的亮度閾值來實現(xiàn)。這樣,函數(shù)就可以根據(jù)背景顏色的亮度來選擇一個合適的字體顏色。if428資訊網(wǎng)——每日最新資訊28at.com

首先,我們定義一個簡單的亮度判斷函數(shù),然后基于背景色的亮度選擇合適的字體顏色。這里舉例說明如何擴(kuò)展前面的函數(shù)以支持多種顏色選擇。if428資訊網(wǎng)——每日最新資訊28at.com

function getBrightness(hexcolor: string): number {  // 標(biāo)準(zhǔn)化十六進(jìn)制格式  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 }   // 藍(lán)色  ];  // 獲取背景色亮度  const backgroundBrightness = getBrightness(backgroundHex);  // 選擇一個亮度合適的顏色  const suitableColor = colors.find(c => backgroundBrightness >= c.minBrightness && backgroundBrightness < c.maxBrightness);  return suitableColor ? suitableColor.color : '#FFFFFF'; // 默認(rèn)返回白色}// 用法示例const backgroundColor = '#005A31'; // 深綠色const textColor = chooseTextColor(backgroundColor);console.log(textColor); // 根據(jù)配置,可能返回不同顏色

在這個例子中,我為函數(shù)增加了幾種顏色選擇。函數(shù)chooseTextColor將檢查背景顏色的亮度,并找到一個在設(shè)定亮度范圍內(nèi)的顏色作為文本顏色。你可以根據(jù)需要調(diào)整顏色選項和它們的亮度界限。if428資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-87252-0.htmlTypeScript封裝一個根據(jù)背景色顯示適合的字體顏色

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: React19 她來了,她來了,他帶著禮物走來了

下一篇: 解密 Python 的變量和對象,它們之間有什么區(qū)別和聯(lián)系呢?

標(biāo)簽:
  • 熱門焦點
  • 影音體驗是真的強(qiáng) 簡單聊聊iQOO Pad

    大公司的好處就是產(chǎn)品線豐富,非常細(xì)分化的東西也能給你做出來,例如早先我們看到了新的vivo Pad2,之后我們又在iQOO Neo8 Pro的發(fā)布會上看到了iQOO的首款平板產(chǎn)品iQOO Pad。雖
  • Redmi Buds 4開箱簡評:才199還有降噪 可以無腦入

    在上個月舉辦的Redmi Note11T Pro系列新機(jī)發(fā)布會上,除了兩款手機(jī)新品之外,Redmi還帶來了兩款TWS真無線藍(lán)牙耳機(jī)產(chǎn)品,Redmi Buds 4和Redmi Buds 4 Pro,此前我們在Redmi Note11T
  • 如何通過Python線程池實現(xiàn)異步編程?

    線程池的概念和基本原理線程池是一種并發(fā)處理機(jī)制,它可以在程序啟動時創(chuàng)建一組線程,并將它們置于等待任務(wù)的狀態(tài)。當(dāng)任務(wù)到達(dá)時,線程池中的某個線程會被喚醒并執(zhí)行任務(wù),執(zhí)行完任
  • 2023年,我眼中的字節(jié)跳動

    此時此刻(2023年7月),字節(jié)跳動從未上市,也從未公布過任何官方的上市計劃;但是這并不妨礙它成為中國最受關(guān)注的互聯(lián)網(wǎng)公司之一。從2016-17年的抖音強(qiáng)勢崛起,到2018年的&ldquo;頭騰
  • 阿里大調(diào)整

    來源:產(chǎn)品劉有媒體報道稱,近期淘寶天貓集團(tuán)啟動了近年來最大的人力制度改革,涉及員工績效、層級體系等多個核心事項,目前已形成一個初步的&ldquo;征求意見版&rdquo;:1、取消P序列
  • 華為HarmonyOS 4.0將于8月4日發(fā)布 或搭載AI大模型技術(shù)

    華為宣布HarmonyOS4.0將于8月4日正式發(fā)布。此前,華為已經(jīng)針對開發(fā)者公布了HarmonyOS4.0,以便于開發(fā)者提前進(jìn)行適配,也因此被曝光出了一些新系統(tǒng)的特性
  • iQOO Neo8 Pro評測:旗艦雙芯加持 最強(qiáng)性能游戲旗艦

    【Techweb評測】去年10月,iQOO推出了一款Neo7手機(jī),該機(jī)搭載了聯(lián)發(fā)科天璣9000+,配備獨(dú)顯芯片Pro+,帶來了同價位段最佳的游戲體驗,一經(jīng)上市便受到了諸多用
  • Counterpoint :OPPO雙旗艦戰(zhàn)略全面落地 高端產(chǎn)品銷量增長22%

    2023年6月30日,全球行業(yè)分析機(jī)構(gòu)Counterpoint Research發(fā)布的《中國智能手機(jī)高端市場白皮書》顯示,中國智能手機(jī)品牌正在尋求高質(zhì)量發(fā)展,中國高端智能
  • 上海舉辦人工智能大會活動,建設(shè)人工智能新高地

    人工智能大會在上海浦江兩岸隆重拉開帷幕,人工智能新技術(shù)、新產(chǎn)品、新應(yīng)用、新理念集中亮相。8月30日晚,作為大會的特色活動之一的上海人工智能發(fā)展盛典人工
Top 主站蜘蛛池模板: 阜宁县| 耒阳市| 汤阴县| 乾安县| 宁陕县| 西宁市| 随州市| 沅江市| 余干县| 广东省| 中卫市| 民权县| 同江市| 洪江市| 元江| 婺源县| 聂拉木县| 锦州市| 津南区| 盱眙县| 建水县| 衡南县| 恩平市| 青海省| 司法| 本溪市| 湘乡市| 封丘县| 衡山县| 郴州市| 永康市| 彭泽县| 金湖县| 贵南县| 佛学| 通海县| 沂水县| 富川| 萨嘎县| 望江县| 聂拉木县|