当前位置:首页 > 科技  > 软件

TypeScript封装一个根据背景色显示适合的字体颜色

来源: 责编: 时间:2024-05-08 09:16:19 87观看
导读方法一在TypeScript中,你可以创建一个函数来确定基于背景颜色的对比色(通常是黑色或白色)作为文本颜色,以确保文本的可读性。为了计算背景颜色与黑白之间的对比度,我们可以使用Web内容可访问性指南(WCAG)的公式。下面是一个

pP928资讯网——每日最新资讯28at.com

方法一

在TypeScript中,你可以创建一个函数来确定基于背景颜色的对比色(通常是黑色或白色)作为文本颜色,以确保文本的可读性。为了计算背景颜色与黑白之间的对比度,我们可以使用Web内容可访问性指南(WCAG)的公式。pP928资讯网——每日最新资讯28at.com

下面是一个简单的TypeScript函数示例,它接受一个背景颜色(十六进制格式)作为输入,然后返回一个推荐的字体颜色(黑色或白色):pP928资讯网——每日最新资讯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分量(亮度),以决定文本颜色使用黑色还是白色。pP928资讯网——每日最新资讯28at.com

请确保输入的颜色格式正确,并且你的应用可以处理不同的输入格式。上面的代码假设输入是一个六位的十六进制颜色值。pP928资讯网——每日最新资讯28at.com

此外,还有更复杂的方法来判断对比度,比如根据WCAG 2.0标准计算颜色之间的对比度比率。这样的计算会更复杂一些,但也可以提供更精确的结果。pP928资讯网——每日最新资讯28at.com

方法二

如果你希望函数能够返回除黑白之外的其他颜色作为字体颜色,你可以通过定义一组颜色和它们的亮度阈值来实现。这样,函数就可以根据背景颜色的亮度来选择一个合适的字体颜色。pP928资讯网——每日最新资讯28at.com

首先,我们定义一个简单的亮度判断函数,然后基于背景色的亮度选择合适的字体颜色。这里举例说明如何扩展前面的函数以支持多种颜色选择。pP928资讯网——每日最新资讯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将检查背景颜色的亮度,并找到一个在设定亮度范围内的颜色作为文本颜色。你可以根据需要调整颜色选项和它们的亮度界限。pP928资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-87252-0.htmlTypeScript封装一个根据背景色显示适合的字体颜色

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: React19 她来了,她来了,他带着礼物走来了

下一篇: 解密 Python 的变量和对象,它们之间有什么区别和联系呢?

标签:
  • 热门焦点
  • K8S | Service服务发现

    K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 一文掌握 Golang 模糊测试(Fuzz Testing)

    一文掌握 Golang 模糊测试(Fuzz Testing)

    模糊测试(Fuzz Testing)模糊测试(Fuzz Testing)是通过向目标系统提供非预期的输入并监视异常结果来发现软件漏洞的方法。可以用来发现应用程序、操作系统和网络协议等中的漏洞或
  • 重估百度丨“晚熟”的百度云,能等到春天吗?

    重估百度丨“晚熟”的百度云,能等到春天吗?

    &copy;自象限原创作者|程心排版|王喻可2016年7月13日,百度云计算战略发布会在北京举行,宣告着百度智能云的正式启程。彼时的会场座无虚席,甚至排队排到了门外,在场的所有人几乎都
  • 2天涨粉255万,又一赛道在抖音爆火

    2天涨粉255万,又一赛道在抖音爆火

    来源:运营研究社作者 | 张知白编辑 | 杨佩汶设计 | 晏谈梦洁这个暑期,旅游赛道彻底火了:有的「地方」火了&mdash;&mdash;贵州村超旅游收入 1 个月超过 12 亿;有的「博主」火了&m
  • 品牌洞察丨服务本地,美团直播成效几何?

    品牌洞察丨服务本地,美团直播成效几何?

    来源:17PR7月11日,美团App首页推荐位出现&ldquo;美团直播&rdquo;的固定入口。在直播聚合页面,外卖&ldquo;神枪手&rdquo;直播间、美团旅行直播间、美团买菜直播间等均已上线,同时
  • OPPO、vivo、小米等国内厂商Q2在印度智能手机市场份额依旧高达55%

    OPPO、vivo、小米等国内厂商Q2在印度智能手机市场份额依旧高达55%

    7月20日消息,据外媒报道,研究机构的报告显示,在全球智能手机出货量同比仍在下滑的大背景下,印度这一有潜力的市场也未能幸免,出货量同比也有下滑,多家厂
  • 质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
  • DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    10月30日,据韩国媒体消息,自今年年初以来一直在上涨的 DRAM 存储器的交易价格仅在本月就下跌了近 10%,此次是全年首次降价,而NAND 闪存本月价格与上月持平。市
  • 北京:科技教育体验基地开始登记

    北京:科技教育体验基地开始登记

      北京“科技馆之城”科技教育体验基地登记和认证工作日前启动。首批北京科技教育体验基地拟于2023年全国科普日期间挂牌,后续还将开展常态化登记。  北京科技教育体验基
Top
Baidu
map