Mermaid 怎么应用 CSS 样式

我在文档里插入了一个 Mermaid 语法写的甘特图,想对这个块应用一个自定义的 CSS 样式,具体该怎么操作?

找了一个下午也没有找到具体的操作办法,对 CSS 不是很懂,大概了解到是通过块属性去定义,但是具体该怎么弄呢?

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    28445 引用 • 119765 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    11154 引用 • 50649 回帖 • 52 关注

相关帖子

被采纳的回答

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • Mermaid 生成的是 SVG,想改样式有难度,至少我不懂

    1 回复
  • hellofish0723

    Mermaid 官方语法支持 CSS 样式么,也不行吗?😢

  • shawnkurt

    doge 搬运工

    Yes, you can use CSS to modify Mermaid graphics, but with important limitations due to how Mermaid renders diagrams using shadow DOM.

    Key Points on Using CSS with Mermaid

    1. Shadow DOM Limits Direct CSS Overrides

    Mermaid encapsulates its diagrams in shadow DOM to prevent ID conflicts and ensure consistent rendering. This means standard CSS rules often won't apply directly unless you use specific techniques or workarounds.

    🔴 According to the MkDocs Material maintainers:
    "Unfortunately, you cannot override Mermaid's CSS with additional CSS... because Mermaid.js diagrams must be encapsulated in shadow DOMs."
    GitHub Discussion #4582

    2. Workarounds and Alternatives

    ✅ Use themeVariables or themeCSS

    Instead of trying to override styles externally, define custom styles during Mermaid initialization:

    mermaid.initialize({
      theme: 'forest',
      themeVariables: {
        primaryColor: '#FF5733',
        lineColor: '#333',
        fontSize: '16px',
        nodeBorder: '2px solid #000'
      }
    });
    

    You can also inject global themeCSS for deeper control.

    ✅ Use !important in CSS

    When injecting styles (e.g., in Obsidian or Zettlr), use !important to override Mermaid’s internal styles:

    .mermaid svg .node rect {
      fill: magenta !important;
      stroke: green !important;
    }
    
    .mermaid svg .cluster rect {
      fill: pink !important;
    }
    

    💡 Tip: Inspect the rendered SVG using browser DevTools to find correct selectors.

    ✅ Define CSS Classes in Markdown

    You can define reusable CSS classes and apply them in diagrams:

    .class green-styled {
      fill: #D5E8D4 !important;
      stroke: #82B366 !important;
      color: #000 !important;
    }
    

    Then use it in Mermaid:

    graph LR A[Node A] --> B[Node B] class A green-styled

    3. Platform-Specific Tips

    • Obsidian: Custom CSS can be added via the appearance settings. Use .mermaid selectors with !important.
    • Zettlr: Modify the theme CSS directly (e.g., body #editor .CodeMirror .mermaid-chart).
    • Docusaurus/MkDocs: You may need to swizzle components or rebuild the theme to inject custom Mermaid config.

推荐标签 标签

  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    5 引用 • 16 回帖 • 3 关注
  • OneDrive
    2 引用 • 3 关注
  • Access
    1 引用 • 3 回帖 • 14 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    293 引用 • 4496 回帖 • 688 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    119 引用 • 54 回帖
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    146 引用 • 442 回帖
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 174 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖
  • Outlook
    1 引用 • 5 回帖
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    327 引用 • 1395 回帖
  • CodeMirror
    2 引用 • 17 回帖 • 197 关注
  • 电影

    这是一个不能说的秘密。

    125 引用 • 610 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • Notion

    Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.

    10 引用 • 80 回帖 • 1 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 72 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    248 引用 • 1342 回帖
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 2 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    110 引用 • 153 回帖
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 3 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    213 引用 • 2044 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 249 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 740 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖 • 1 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 724 关注
  • V2Ray
    1 引用 • 15 回帖 • 4 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    59 引用 • 25 回帖 • 5 关注