服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服务器之家 - 编程语言 - JavaScript - js教程 - TypeScript封装一个根据背景色显示适合的字体颜色

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

2024-05-08 17:42NativeBase js教程

在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将检查背景颜色的亮度,并找到一个在设定亮度范围内的颜色作为文本颜色。你可以根据需要调整颜色选项和它们的亮度界限。

原文地址:https://www.toutiao.com/article/7363096876352143883/

延伸 · 阅读

精彩推荐
  • js教程详解 TypeScript 函数声明和重载

    详解 TypeScript 函数声明和重载

    在 JavaScript 中,函数是构建应用的一块基石,我们可以使用函数抽离可复用的逻辑、抽象模型、封装过程。在TypeScript中,函数仍然是最基本、最重要的概念...

    前端充电宝7302022-01-05
  • js教程JavaScript中跨域问题的深入理解

    JavaScript中跨域问题的深入理解

    这篇文章主要给大家介绍了关于JavaScript中跨域问题的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    三七安7012022-02-10
  • js教程JavaScript事件概念详解(区分静态注册和动态注册)

    JavaScript事件概念详解(区分静态注册和动态注册)

    这篇文章主要介绍了JavaScript事件(区分静态注册和动态注册)的相关资料,帮助大家更好的理解和学习使用JavaScript,感兴趣的朋友可以了解下...

    皮卡丘和羊宝贝7122022-01-17
  • js教程requestAnimationFrame定时动画屏幕刷新率节流示例浅析

    requestAnimationFrame定时动画屏幕刷新率节流示例浅析

    这篇文章主要为大家介绍了requestAnimationFrame定时动画屏幕刷新率节流示例浅析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日...

    掘金最后一个老实人10032023-06-12
  • js教程微信小程序学习之自定义滚动弹窗

    微信小程序学习之自定义滚动弹窗

    这篇文章主要给大家介绍了关于微信小程序学习之自定义滚动弹窗的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考...

    юноша9302021-12-15
  • js教程JavaScript实现循环轮播图

    JavaScript实现循环轮播图

    这篇文章主要为大家详细介绍了JavaScript实现循环轮播图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    休息休息夏3852022-02-27
  • js教程你不知道的 JS 沙箱隔离

    你不知道的 JS 沙箱隔离

    本文接下来的内容,将介绍我在探索基于 Web Worker 实现 JavaScript 沙箱隔离方案过程中的一些资料收集、理解以及我的踩坑和思考的过程。...

    前端大全10472021-12-29
  • js教程js实现鼠标切换图片(无定时器)

    js实现鼠标切换图片(无定时器)

    这篇文章主要为大家详细介绍了js实现鼠标切换图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    枫思然8232022-01-10