F 的分享 | 如何在思源中使用 KaTex 宏

本贴最后更新于 230 天前,其中的信息可能已经水流花落

思源笔记当中「设置」-「编辑器」中有一个「Katex 宏定义」的设置选项,长久以来一直被人忽略,甚至连官方文档里面都没有提到他——但实际上这个东西非常有用。

image.png

在 KaTeX 中,「宏」允许你将一个长且复杂的表达式缩写成一个简短的标识符。

他实际上就是一种字符串替换规则:首先定义一个简短的字符串(宏名),并告诉 KaTeX 当你写下这个宏名时,应该用哪个更长的字符串(通常是一个数学表达式)来替换它。

这样一来,在编写数学公式时,只需输入宏名,KaTeX 就会自动将其替换为对应的完整表达式。这使得重复输入复杂表达式变得快速且不易出错。

定义宏首先要指定一个用 \ 开头的文本,比如 \foo;然后,指定一个字符串来描述这个宏应该展开成什么,就像在一个字典或者映射表中一样。在实际使用的时候,KaTex 引擎就会用后面的替代文本来替代前面的键。

思源中支持用 Json 格式来声明宏定义,其中的键是宏的名称,值是宏的替代文本。例如下面这个例子中,当你在 KaTeX 中使用 \foo 时,它会被替换为 {x^2}

{
  "\\foo": "{x^2}"
}

注:之所以这里用 \\foo 而不是 \foo 是因为程序处理 json 的时候,需要转义 \ 字符。

更加复杂的案例

这里给一个更复杂一些的案例:

{
  "\\aligned": "\\begin{aligned}#1\\end{aligned}",
}

有了这个宏只需写 \aligned{...},并把方程组作为参数放在大括号中,就能定义一个 aligned 环境。

我们可以使用刚刚定义的 \aligned 宏来整洁地表示一个复数的极坐标和直角坐标之间的转换。

\aligned{
&z = (real, imag) = (M, \theta)\\
& M = \sqrt{real^2 + imag^2}\\
&\theta = \arctan{\left(\frac{imag}{real}\right)}\\
& real = M\cos{\theta}\\
& imag = M\sin{\theta}
}

以上代码就会被展开为:

\begin{aligned}
&z = (real, imag) = (M, \theta)\\
& M = \sqrt{real^2 + imag^2}\\
&\theta = \arctan{\left(\frac{imag}{real}\right)}\\
& real = M\cos{\theta}\\
& imag = M\sin{\theta}
\end{aligned}

宏参数

上面的案例用到了宏参数,它用 # 后跟一个数字表示,例如 #1,#2 等。这些数字指的是宏使用时相应位置的参数。

例如,如果定义了一个宏 \foo 来表示某个带有一个参数的数学操作,就像这样:

{
  "\\foo": "f(#1)"
}

在这里,#1 将会被替换为在使用宏时提供的第一个参数。当你在数学表达式中写下 \foo{x} 时,KaTeX 会将其展开为 f(x)

如果定义的宏需要多个参数,你可以在定义中包含 #1,#2,#3 等,以此类推,对应使用时的第一、第二、第三个括号里面的内容。

举一个多参数宏的例子:

{
  "\\binomial": "\\left(\\frac{#1}{#2}\\right)"
}

在这个宏定义中,\binomial 用来创建一个二项式系数。使用 \binomial{n}{k} 时,#1 会被替换为 n,而 #2 会被替换为 k,所以它会展开为 \left(\frac{n}{k}\right)

\binomial{2}{3}
\left(\frac{2}{3}\right)
  • 思源笔记

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

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

    23020 引用 • 92604 回帖
  • KaTex
    3 引用 • 9 回帖
1 操作
Frostime 在 2024-05-06 11:18:03 更新了该帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    343 引用 • 723 回帖
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    76 引用 • 1737 回帖 • 1 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 483 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 317 关注
  • danl
    146 关注
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 694 关注
  • 自由行
    4 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 4 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 1 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 147 关注
  • Kubernetes

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

    110 引用 • 54 回帖 • 1 关注
  • 反馈

    Communication channel for makers and users.

    123 引用 • 913 回帖 • 250 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 789 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 60 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 637 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1520 回帖
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 363 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    407 引用 • 3578 回帖
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    149 引用 • 257 回帖
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 465 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 29 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 101 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 668 关注