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

當前位置:首頁 > 科技  > 軟件

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

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

XhR28資訊網——每日最新資訊28at.com

方法一

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

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

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分量(亮度),以決定文本顏色使用黑色還是白色。XhR28資訊網——每日最新資訊28at.com

請確保輸入的顏色格式正確,并且你的應用可以處理不同的輸入格式。上面的代碼假設輸入是一個六位的十六進制顏色值。XhR28資訊網——每日最新資訊28at.com

此外,還有更復雜的方法來判斷對比度,比如根據WCAG 2.0標準計算顏色之間的對比度比率。這樣的計算會更復雜一些,但也可以提供更精確的結果。XhR28資訊網——每日最新資訊28at.com

方法二

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

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

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將檢查背景顏色的亮度,并找到一個在設定亮度范圍內的顏色作為文本顏色。你可以根據需要調整顏色選項和它們的亮度界限。XhR28資訊網——每日最新資訊28at.com

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

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

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

下一篇: 解密 Python 的變量和對象,它們之間有什么區別和聯系呢?

標簽:
  • 熱門焦點
  • 紅魔電競平板評測:大屏幕硬實力

    前言:三年的疫情因為要上網課的原因激活了平板市場,如今網課的時代已經過去,大家的生活都恢復到了正軌,這也就意味著,真正考驗平板電腦生存的環境來了。也就是面對著這種殘酷的
  • 一篇聊聊Go錯誤封裝機制

    %w 是用于錯誤包裝(Error Wrapping)的格式化動詞。它是用于 fmt.Errorf 和 fmt.Sprintf 函數中的一個特殊格式化動詞,用于將一個錯誤(或其他可打印的值)包裝在一個新的錯誤中。使
  • 一篇文章帶你了解 CSS 屬性選擇器

    屬性選擇器對帶有指定屬性的 HTML 元素設置樣式。可以為擁有指定屬性的 HTML 元素設置樣式,而不僅限于 class 和 id 屬性。一、了解屬性選擇器CSS屬性選擇器提供了一種簡單而
  • 共享單車的故事講到哪了?

    來源丨海克財經與共享充電寶相差不多,共享單車已很久沒有被國內熱點新聞關照到了。除了一再漲價和用戶直呼用不起了。近日多家媒體再發報道稱,成都、天津、鄭州等地多個共享單
  • 東方甄選單飛:有些鳥注定是關不住的

    作者:彭寬鴻來源:華爾街科技眼&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;東方甄選創始人俞敏洪帶隊的&ldquo;7天甘肅行&rdquo;直播活動已在近日順利收官。成立后一
  • 微博大門常打開,迎接海外畫師漂洋東渡

    作者:互聯網那些事&ldquo;起猛了,我能看得懂日語了&rdquo;。&ldquo;為什么日本人說話我能聽懂?&rdquo;&ldquo;中文不像中文,日語不像日語,但是我竟然看懂了&rdquo;&hellip;&hell
  • 三星電子Q2營收60萬億韓元 存儲業務營收同比仍下滑超過50%

    7月27日消息,據外媒報道,從三星電子所發布的財報來看,他們主要利潤來源的存儲芯片業務在今年二季度仍不樂觀,營收同比仍在大幅下滑,所在的設備解決方案
  • 半導體需求下滑 三星電子DS業務部門今年營業虧損預計超10萬億韓元

    7月17日消息,據外媒報道,去年下半年開始的半導體需求下滑,影響到了三星電子、SK海力士、英特爾等諸多廠商,營收明顯下滑,部分廠商甚至出現了虧損。作為
  • 上海舉辦人工智能大會活動,建設人工智能新高地

    人工智能大會在上海浦江兩岸隆重拉開帷幕,人工智能新技術、新產品、新應用、新理念集中亮相。8月30日晚,作為大會的特色活動之一的上海人工智能發展盛典人工
Top 主站蜘蛛池模板: 图木舒克市| 垫江县| 娄烦县| 昭苏县| 米脂县| 绥阳县| 卢湾区| 达日县| 长治市| 佛坪县| 新余市| 慈溪市| 张北县| 体育| 永济市| 松原市| 宁海县| 建湖县| 垦利县| 江北区| 丰顺县| 云阳县| 龙口市| 建平县| 邯郸县| 宣化县| 玛沁县| 高安市| 五河县| 托克逊县| 永吉县| 从江县| 德庆县| 温州市| 习水县| 庄河市| 石城县| 大理市| 余江县| 宁明县| 崇文区|