如何使用 TypeScript 在 Material UI 上添加自定义颜色名称?

2023-11-21

我正在使用 TypeScript 使用 Material UI,并希望向我的主题添加自定义颜色。一切工作正常,除了 VSCode linter 向我显示下一条消息。

Type '{ tan: string; lightRed: string; red: string; offBlack: string; white: string; }' is not assignable to type 'Partial<CommonColors>'.
  Object literal may only specify known properties, and 'tan' does not exist in type 'Partial<CommonColors>'.

在开发和构建方面工作正常,唯一的抱怨是错误消息。我添加了一个自定义类型来尝试解决,但它不起作用。

const theme = createTheme({
  palette: {
    common: {
      tan,
      lightRed,
      red,
      offBlack,
      white,
    },
  },
});
import {
  PaletteOptions,
  CommonColors,
} from '@material-ui/core/styles/createPalette';

interface CustomColors extends CommonColors {
  tan: string?;
  lightRed: string;
  red: string;
  offBlack: string;
}

declare module '@material-ui/core/styles/createPalette' {
  export interface PaletteOptions {
    common: CustomColors;
  }
}

我添加到tsconfig.json文件。 tan、red 和其余值被声明为字符串。关于如何解决这个问题有任何线索吗?提前致谢。


我不能声称对模块增强有很好的理解,但我已经在自己的应用程序中完成了它(也适用于调色板中的自定义颜色),并且当我使用与我自己的应用程序中相同的方法时,它适用于您的场景。我的理解是,您只需要指定增强 - 您不需要创建扩展现有类型的新类型。就你而言,你只想增强CommonColors.

以下方法似乎有效:

import "@mui/material/styles/createPalette";
declare module "@mui/material/styles/createPalette" {
  interface CommonColors {
    tan: string;
    lightRed: string;
    red: string;
    offBlack: string;
  }
}

Edit TypeScript custom colors

在我的示例中,我将此代码放在createPalette.d.ts文件和该文件的名称似乎确实很重要(尽管它位于哪个目录似乎并不重要,只要它位于编译器查看的目录内即可)。直接把代码放进去也很好用index.tsx或者直接在执行的 TypeScript 文件中createTheme.

相关回答:

  • Typescript 模块增强不起作用:类型“PaletteColorOptions”上不存在属性“main”
  • MUI 覆盖滑块颜色选项与模块增强
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何使用 TypeScript 在 Material UI 上添加自定义颜色名称? 的相关文章

随机推荐

  • Typescript 接口默认值

    我在 TypeScript 中有以下界面 interface IX a string b any c AnotherType 我声明该类型的变量并初始化所有属性 let x IX a abc b null c null 然后我稍后在 ini
  • 读取csv文件中的特定行,python

    In an CSV使用python的文件我们可以逐行或逐行读取所有文件 我想读取特定行 第24行示例 而不读取所有文件和所有行 您可以使用行缓存 getline linecache getline 文件名 lineno module glo
  • 使用高级加密标准算法 (AES) 在 Typescript 中加密字符串并在 C# 中解密

    我很难在打字稿中实现加密并在 C 中实现解密 在在这里发布问题之前 我用 Google 搜索并找到了一些链接 但这些链接与 JavaScript 而不是打字稿相关 在 javascript 中加密并使用 AES 算法在 C 中解密 使用 a
  • 如何告诉 Eclipse 使用与通常不同的 JRE 版本来编译和构建项目?

    我不确定这个问题是否已得到完整回答 或者我的标题是否足够描述我的情况 但我被要求将项目从使用 Ant 构建转换为 Maven 这部分还不错 但我被告知这个应用程序是专门为 JRE 1 5 版而不是我一直在处理的其他应用程序使用的 JRE 6
  • 为什么不使用 GlobalScope.launch?

    我读到了这个用法Globalscope非常沮丧 here 我有一个简单的用例 对于我收到的每条 kafka 消息 假设是一个 Id 列表 我必须将其拆分并同时为每个 Id 调用休息服务 并等待其完成并继续执行其他同步任务 该应用程序中没有其
  • 获取最后一个插入 ID 的标准方法是什么?

    获取最后插入的id的sql标准是什么 如果有这样的事情的话 mysql LAST INSERT ID postgresql 返回 f idmssql SCOPE IDENTITY 更多例子在这里 我的意思是 所有数据库都有不同的实现 这样的
  • AMQP C++ 实现 [关闭]

    Closed 此问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 目前不接受答案 我们正在编写需要消息传递的 C 代码 是否有免费 开源且稳定的 AMQP 服务器可用 并且具有同样稳定的 C 客户端库 我们还需要向用户提供代码的
  • Xamarin.Forms - 用于异步操作的 BeginInvokeOnMainThread

    我熟悉有关使用 Device BeginInvokeOnMainThread 在 UI 线程上更新 UI 元素的规则 但是我有一个需要在 UI 线程上运行的操作 该操作实际上是一个任务 例如 XLabs Forms Mvvm 上的 Push
  • 如何停用 GMail 计量电子邮件?

    如何停用 google apps 脚本 活动报告 我尝试了gmail Meter 最后删除了google docs中的文档 现在 每天晚上我都会收到一份报告 如下 Ihr Skript Gmail Meter konnte nicht er
  • React - 如何在 Jest 中对 API 调用进行单元测试?

    我有一堆 API 调用 我想对其进行单元测试 据我所知 单元测试 API 调用并不涉及实际进行这些 API 调用 据我所知 您会模拟这些 API 调用的响应 然后测试 DOM 更改 但我目前正在努力做到这一点 我有以下代码 App js f
  • 在 SQL Server 上使用或不使用 CONSTRAINT 关键字的区别

    使用和不使用有什么区别CONSTRAINT在 SQL Server 上使用外键时的关键字 我注意到在这个特定情况下显然两者的工作原理相同 没有CONSTRAINT CREATE TABLE ClientsPhones ClientPhone
  • Freemarker 转义 freemarker

    我正在使用 freemarker 生成 freemarker 模板 但我需要一些方法来逃避 freemarker 标签 我该如何逃脱 lt list gt 标签或 expression 您还可以使用 expression 如果您发现 嵌套令
  • XML 模式如何通过枚举限制属性

    我有以下 XML 标签
  • 如何在C++中显示固定位数而不进行四舍五入

    我有这个代码 非常基本 include
  • d3.js:将数据从父节点传递到子节点

    我正在使用 d3 制作堆积条形图 数据是一个数组 每个栏都有一个对象 例如 喜欢 然后每个对象都包含一个值数组 这些值驱动每个条形的各个矩形 data key likes values key blue frog value 1 key g
  • 用“.”分割字符串(点)处理缩写时

    我发现这很难解释 所以我将首先举几个我想要实现的目标之前 之后的例子 输入示例 你好世界 这是一个测试 特警队 S W A T s w a t 2001 A 太空奥德赛 想要的输出 你好世界 这是一个测试 特警队 SWAT swat 200
  • 如何使 mailto 主题和正文在 gmail 等中工作?

    下午好 我有一个带有 mailto 链接的网站 用于向我母亲的公司发送电子邮件 非常标准的东西 我最近尝试添加一些其他位来获得标准主题和正文 当我使用 Outlook 在我的工作电脑上 时 它可以工作 但如果我使用自动打开 gmail 的家
  • 通过反射访问抽象类的属性

    我有一个抽象类 让我们命名它Base 该类包含一些属性 而且 我还有另一个类 继承自 classBase 让我们命名它Child Child并不抽象 我想从类访问属性Base与反射 和only中声明的那些属性Base 下面的代码当然是不可能
  • 为什么 NSMetadataQueryDidUpdateNotification 被快速连续调用多次?

    为了监控 iCloud 容器中的文件更改 我注册了 NSNotificationCenter defaultCenter addObserver self selector selector processiCloudUpdates nam
  • 如何使用 TypeScript 在 Material UI 上添加自定义颜色名称?

    我正在使用 TypeScript 使用 Material UI 并希望向我的主题添加自定义颜色 一切工作正常 除了 VSCode linter 向我显示下一条消息 Type tan string lightRed string red st