Uniswap V2 核心问题解答
以下内容基于 Uniswap V2 机制整理,涵盖 AMM 原理、滑点、三明治攻击、流动性提供、无常损失等核心概念。
1. 什么是 AMM?它和订单簿模式有什么区别?
AMM(自动做市商)
AMM(Automated Market Maker)是一种通过数学公式(算法)自动确定价格、无需人工报价的去中心化交易机制。
用户在 Uniswap 等 AMM 协议中交易时,价格由流动性池(Liquidity Pool)中的资产比例根据预设公式自动计算,用户与合约本身进行交易,而不是与另一个对手方撮合。
核心对比:AMM vs 订单簿模式
| 维度 | AMM(Uniswap) | 订单簿模式(CEX / DEX) |
|---|---|---|
| 定价方式 | 池内资产比例自动计算(算法驱动) | 买卖盘挂单手动撮合 |
| 对手方 | 流动性池(LP),无需主动对手方 | 必须有另一方挂单接单 |
| 价格发现 | 由池内资产比例决定,有滑点 | 盘口深度决定,更精准 |
| 流动性来源 | 任何人存入资产成为 LP | 做市商或专业做市机构 |
| 交易体验 | 随时可交易(哪怕池子小) | 需等待撮合,大额可能无法成交 |
| 适合场景 | 小额现货交换、新资产发行 | 大额交易、限价挂单 |
简单理解:AMM = "菜市场自动称重定价机",你放入多少菜、机器自动按比例算出价格;订单簿 = 你和摊贩讨价还价挂牌交易。
2. AMM 的核心算法是什么?
Uniswap V2 使用 恒定乘积做市商公式(Constant Product Market Maker, CPMM):
x × y = k
x= 池中 Token A 的数量y= 池中 Token B 的数量k= 恒定乘积(交易前后不变)
交易机制推导
假设池中有 x 单位 Token A 和 y 单位 Token B,用户用 Δx 数量的 A 换取 B:
(x + Δx) × (y - Δy) = k = x × y
整理得:
Δy = y - (x × y) / (x + Δx)
= (y × Δx) / (x + Δx)
特性
| 特性 | 说明 |
|---|---|
| 无边界的流动性 | 池永远不会枯竭------价格曲线是双曲线,趋向无穷但不相交 |
| 价格与深度相关 | 交易量越大,x 相对于池总量越小,价格滑点越高 |
| 无常损失的根源 | 池内资产比例变化时,LP 的实际持仓与单纯持有相比产生差异(见第 6 节) |
图示(价格曲线)
价格
↑
│╲
│ ╲ k 值越大,曲线越平缓(大池滑点小)
│ ╲
│ ╲
│ ╲
└────────────→ 池中 Token A 比例
3. 什么是滑点?用户交易时如何避免滑点过高?
滑点(Slippage)
滑点是指用户期望成交价格与实际成交价格之间的差异。
在 AMM 中,滑点的产生原因是:x × y = k 公式下,每一笔交易都会改变池内资产比例,从而改变后续交易的成交价格。
- 交易量越大 → 池子相对越浅 → 滑点越高
- 池子越小 → 同样的交易量滑点越大
滑点公式
对于一笔用 Δx 换取 Δy 的交易:
滑点比例 = (预期价格 - 实际价格) / 预期价格
实际价格 = Δy / Δx
市场边际价格 = y / x
如何避免滑点过高?
1. 设置滑点容忍度(Slippage Tolerance)
- 在 Uniswap 界面手动设置滑点上限(默认 0.5%,可调低至 0.1%)
- 若实际滑点超过设定值,交易自动回滚,不执行
2. 优先选择流动性深的大池
- 同一交易对,优先选 TVL(总锁仓量)更高的池子
- 如 ETH/USDC 大池远小于小交易对池
3. 拆分大单
- 将一笔大额交易拆成多笔小交易,减少单笔滑点
- 注意:每笔仍有少量滑点,且后几笔可能价格更差
4. 关注 Gas 费用时机
- 网络拥堵时 Gas 费高,滑点+矿工费双重损耗
- 低 Gas 时段交易整体更划算
5. 使用 MEV 保护工具
- 如 Flashbots Protect,将交易通过私密 RPC 提交,减少被三明治攻击的风险(见第 4 节)
4. 什么是三明治攻击?如何降低被三明治攻击的风险?
三明治攻击(Sandwich Attack)
三明治攻击是一种利用交易顺序操控价格的 MEV(矿工可提取价值)攻击,攻击者将受害者的交易夹在两笔自己提交的交易中间。
攻击步骤
步骤 1:攻击者发现受害者提交了一笔 AMM 交易(如用 ETH 买 ABC)
↓
步骤 2:攻击者先于受害者交易------用 ABC 买 ETH(推高 ABC 价格)
↓
步骤 3:受害者的交易在更高价格成交(买入被"夹高")
↓
步骤 4:攻击者立即卖出 ABC(套利,价格已对自己有利)
关键点
- 攻击者利用受害者的滑点设置来预测价格走向
- 如果受害者设置了足够高的滑点容忍度,攻击者就能确保自己有利可图
- 受害者支付的成交价格 > 正常市场价值,差额被攻击者获取
如何降低被三明治攻击的风险?
1. 设置较低的滑点容忍度
- 滑点设得越低,攻击者利润空间越小
- 建议:普通交易设 0.5% 以内,高波动资产不超过 1%
2. 开启 MEV 保护
- 使用 Flashbots Protect、OpenMEV 等工具
- 私密 RPC 将交易直接提交给验证者,跳过公共 mempool
3. 使用大池交易
- 流动性好的大池滑点小,三明治攻击利润空间有限
4. 批量交易时分散滑点设置
- 如果必须分批交易,不要每笔都用相同的滑点
5. 避免在 mempool 暴露大单
- 大额交易尤其容易被机器人监控和狙击
- 考虑使用 TWAP(时间加权平均价格)订单或私有交易通道
5. LP 的作用是什么?
LP(Liquidity Provider)= 流动性提供者
LP 是指将自有资产存入 Uniswap 流动性池,为交易者提供可交易深度的用户或机构。
LP 的核心作用
LP 存入:Token A(如 ETH)+ Token B(如 USDC)
↓
成为交易对手方:所有交易都与 LP 的资金池成交
↓
收取手续费:每笔交易 LP 按份额比例获得 0.3% 的手续费收益
具体职责与收益
| 职责 | 说明 |
|---|---|
| 提供流动性 | 让交易随时可发生,无需等待对手方 |
| 承担交易风险 | 池中资产比例随交易变化,LP 被动承受 |
| 确定交易对价格 | 通过资产比例间接影响价格(但非主动定价) |
| 获得手续费收入 | 按份额比例分配池内产生的 0.3% 交易手续费 |
Uniswap V2 手续费分配(0.3% / 笔)
每笔交易手续费 = 0.3%
手续费全部归 LP 按份额分配
项目方不抽成(V2 版本),V3 引入了协议手续费(可切换)
成为 LP 的基本流程
- 准备两种等值的资产(如 ETH + USDC)
- 存入 Uniswap V2 对应的流动性池
- 获得 LP Token(代表你在池中的份额)
- LP Token 可随时赎回,换回本金 + 累计手续费
⚠️ 注意:LP 不是稳赚不赔的------无常损失(见第 6 节)可能导致本金缩水,手续费收益需要能覆盖无常损失才算盈利。
6. 什么是无常损失?如何计算?
无常损失(Impermanent Loss, IL)
无常损失是指 LP 将资产存入 AMM 池后,若资产价格发生变化,其池内持仓价值低于不做任何操作、单纯持有原资产的价值差异。
之所以叫"无常"(impermanent),是因为如果价格回归,损失会消失------但实际中价格往往不回原位,因此损失经常是实际且永久的。
无常损失的计算
设初始存入时两种资产价值相等:
初始状态:
- 价格比率:P₀ = Token A / Token B 的初始价格
- 存入:x₀ 单位 Token A + 等值 y₀ 单位 Token B
- x₀ × y₀ = k(恒定乘积)
存入时的总价值(以 Token B 计价):
V₀ = x₀ × P₀ + y₀
经过价格变化,新价格比率变为 P₁:
池内重新平衡后(x × y = k 仍成立):
x₁ = √(k × P₁) (Token A 数量)
y₁ = √(k / P₁) (Token B 数量)
池内持仓价值:
V_pool = x₁ × P₁ + y₁
对比:如果什么都不做,单纯持有初始资产:
V_hold = x₀ × P₁ + y₀
无常损失:
无常损失 = V_hold - V_pool
无常损失比例 = (V_hold - V_pool) / V_hold
简化公式
当两种资产初始价值相等,价格变化倍数为 r = P₁ / P₀ 时:
无常损失比例 = 2√r / (1 + r) - 1
| 价格变化倍数 r | 无常损失比例 |
|---|---|
| 1.0x(不变) | 0.00% |
| 1.25x | -0.60% |
| 1.50x | -2.02% |
| 2.00x | -5.72% |
| 3.00x | -13.40% |
| 5.00x | -25.47% |
| 10.00x | -42.45% |
无常损失的直观理解
假设初始存入:1 ETH + 1000 USDC(ETH = $1000)
情况 A:ETH 涨到 $2000
池内自动变成:0.707 ETH + 1414 USDC
池价值 = $1414 + $1414 = $2828
持有不动:$2000 + $1000 = $3000
无常损失 = $3000 - $2828 = $172(约 -5.7%)
情况 B:ETH 跌到 $500
池内自动变成:1.414 ETH + 707 USDC
池价值 = $707 + $707 = $1414
持有不动:$500 + $1000 = $1500
无常损失 = $1500 - $1414 = $86(约 -5.7%)
如何降低无常损失的影响?
| 方法 | 说明 |
|---|---|
| 存入稳定币交易对 | 如 USDC/USDT,汇率波动极小,几乎无无常损失 |
| 存入相关性高的资产对 | 如 ETH/stETH,波动同步,IL 较小 |
| 选择无常损失保护的产品 | 如 Balancer 变体池、Uni V3 集中流动性(部分区间) |
| 长期持有视角 | 手续费收益需超过无常损失才值得做 LP |
| 使用 DeFi 收益聚合器 | 自动寻找手续费 APY 最高、IL 最低的策略 |
附录:核心概念速查表
| 术语 | 英文 | 一句话定义 |
|---|---|---|
| AMM | Automated Market Maker | 用算法自动定价的去中心化交易协议 |
| LP | Liquidity Provider | 为 AMM 池提供流动性的用户 |
| 滑点 | Slippage | 成交价与预期价的偏差 |
| 三明治攻击 | Sandwich Attack | 用抢先+滞后交易夹击受害者的 MEV 攻击 |
| 无常损失 | Impermanent Loss | LP 持仓价值低于单纯持有的差额 |
| 恒定乘积公式 | x × y = k | Uniswap V2 的核心定价算法 |
| TVL | Total Value Locked | 池中锁定的总资产价值 |
| MEV | Miner Extractable Value | 矿工/验证者可提取的最大价值 |
---@TOC
欢迎使用Markdown编辑器
你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。
新的改变
我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:
- 全新的界面设计 ,将会带来全新的写作体验;
- 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
- 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
- 全新的 KaTeX数学公式 语法;
- 增加了支持甘特图的mermaid语法[1](#甘特图的mermaid语法1) 功能;
- 增加了 多屏幕编辑 Markdown文章功能;
- 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
- 增加了 检查列表 功能。
功能快捷键
撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G
查找:Ctrl/Command + F
替换:Ctrl/Command + G
合理的创建标题,有助于目录的生成
直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC语法后生成一个完美的目录。
如何改变文本的样式
强调文本 强调文本
加粗文本 加粗文本
标记文本
删除文本
引用文本
H2O is是液体。
210 运算结果是 1024.
插入链接与图片
链接: link.
图片:
带尺寸的图片:
居中的图片:
居中并且带尺寸的图片:
当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。
如何插入一段漂亮的代码片
去博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.
javascript
// An highlighted block
var foo = 'bar';
生成一个适合你的列表
- 项目
- 项目
- 项目
- 项目
- 项目1
- 项目2
- 项目3
- 计划任务
- 完成任务
创建一个表格
一个简单的表格是这么创建的:
| 项目 | Value |
|---|---|
| 电脑 | $1600 |
| 手机 | $12 |
| 导管 | $1 |
设定内容居中、居左、居右
使用:---------:居中
使用:----------居左
使用----------:居右
| 第一列 | 第二列 | 第三列 |
|---|---|---|
| 第一列文本居中 | 第二列文本居右 | 第三列文本居左 |
SmartyPants
SmartyPants 是一个文本转换工具,主要功能是将普通的 ASCII 标点符号自动转换为更美观的印刷体标点符号。例如:
| 原始符号 | 转换后 | 说明 |
|---|---|---|
"引号" |
"引号" | 直引号变弯引号 |
'单引号' |
'单引号' | 直单引号变弯单引号 |
-- |
-- | 两个连字符变短破折号 |
--- |
--- | 三个连字符变长破折号 |
... |
... | 三个点变省略号 |
创建一个自定义列表
:
Text-to- conversion tool
: John
: Luke
如何创建一个注脚
一个具有注脚的文本。[2](#2)
注释也是必不可少的
Markdown将文本转换为 。
KaTeX数学公式
您可以使用渲染LaTeX数学表达式 KaTeX:
Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n−1)!∀n∈N 是通过欧拉积分
Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=∫0∞tz−1e−tdt.
你可以找到更多关于的信息 LaTeX 数学表达式here.
新的甘特图功能,丰富你的文章
#mermaid-svg-KZGjSKxEjNr5zn4x{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}@keyframes edge-animation-frame{from{stroke-dashoffset:0;}}@keyframes dash{to{stroke-dashoffset:0;}}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-animation-slow{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 50s linear infinite;stroke-linecap:round;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-animation-fast{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 20s linear infinite;stroke-linecap:round;}#mermaid-svg-KZGjSKxEjNr5zn4x .error-icon{fill:#552222;}#mermaid-svg-KZGjSKxEjNr5zn4x .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-thickness-normal{stroke-width:1px;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-thickness-invisible{stroke-width:0;fill:none;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-KZGjSKxEjNr5zn4x .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-KZGjSKxEjNr5zn4x .marker{fill:#333333;stroke:#333333;}#mermaid-svg-KZGjSKxEjNr5zn4x .marker.cross{stroke:#333333;}#mermaid-svg-KZGjSKxEjNr5zn4x svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-KZGjSKxEjNr5zn4x p{margin:0;}#mermaid-svg-KZGjSKxEjNr5zn4x .mermaid-main-font{font-family:"trebuchet ms",verdana,arial,sans-serif;}#mermaid-svg-KZGjSKxEjNr5zn4x .exclude-range{fill:#eeeeee;}#mermaid-svg-KZGjSKxEjNr5zn4x .section{stroke:none;opacity:0.2;}#mermaid-svg-KZGjSKxEjNr5zn4x .section0{fill:rgba(102, 102, 255, 0.49);}#mermaid-svg-KZGjSKxEjNr5zn4x .section2{fill:#fff400;}#mermaid-svg-KZGjSKxEjNr5zn4x .section1,#mermaid-svg-KZGjSKxEjNr5zn4x .section3{fill:white;opacity:0.2;}#mermaid-svg-KZGjSKxEjNr5zn4x .sectionTitle0{fill:#333;}#mermaid-svg-KZGjSKxEjNr5zn4x .sectionTitle1{fill:#333;}#mermaid-svg-KZGjSKxEjNr5zn4x .sectionTitle2{fill:#333;}#mermaid-svg-KZGjSKxEjNr5zn4x .sectionTitle3{fill:#333;}#mermaid-svg-KZGjSKxEjNr5zn4x .sectionTitle{text-anchor:start;font-family:"trebuchet ms",verdana,arial,sans-serif;}#mermaid-svg-KZGjSKxEjNr5zn4x .grid .tick{stroke:lightgrey;opacity:0.8;shape-rendering:crispEdges;}#mermaid-svg-KZGjSKxEjNr5zn4x .grid .tick text{font-family:"trebuchet ms",verdana,arial,sans-serif;fill:#333;}#mermaid-svg-KZGjSKxEjNr5zn4x .grid path{stroke-width:0;}#mermaid-svg-KZGjSKxEjNr5zn4x .today{fill:none;stroke:red;stroke-width:2px;}#mermaid-svg-KZGjSKxEjNr5zn4x .task{stroke-width:2;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskText{text-anchor:middle;font-family:"trebuchet ms",verdana,arial,sans-serif;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutsideRight{fill:black;text-anchor:start;font-family:"trebuchet ms",verdana,arial,sans-serif;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutsideLeft{fill:black;text-anchor:end;}#mermaid-svg-KZGjSKxEjNr5zn4x .task.clickable{cursor:pointer;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskText.clickable{cursor:pointer;fill:#003163!important;font-weight:bold;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163!important;font-weight:bold;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163!important;font-weight:bold;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskText0,#mermaid-svg-KZGjSKxEjNr5zn4x .taskText1,#mermaid-svg-KZGjSKxEjNr5zn4x .taskText2,#mermaid-svg-KZGjSKxEjNr5zn4x .taskText3{fill:white;}#mermaid-svg-KZGjSKxEjNr5zn4x .task0,#mermaid-svg-KZGjSKxEjNr5zn4x .task1,#mermaid-svg-KZGjSKxEjNr5zn4x .task2,#mermaid-svg-KZGjSKxEjNr5zn4x .task3{fill:#8a90dd;stroke:#534fbc;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutside0,#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutside2{fill:black;}#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutside1,#mermaid-svg-KZGjSKxEjNr5zn4x .taskTextOutside3{fill:black;}#mermaid-svg-KZGjSKxEjNr5zn4x .active0,#mermaid-svg-KZGjSKxEjNr5zn4x .active1,#mermaid-svg-KZGjSKxEjNr5zn4x .active2,#mermaid-svg-KZGjSKxEjNr5zn4x .active3{fill:#bfc7ff;stroke:#534fbc;}#mermaid-svg-KZGjSKxEjNr5zn4x .activeText0,#mermaid-svg-KZGjSKxEjNr5zn4x .activeText1,#mermaid-svg-KZGjSKxEjNr5zn4x .activeText2,#mermaid-svg-KZGjSKxEjNr5zn4x .activeText3{fill:black!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .done0,#mermaid-svg-KZGjSKxEjNr5zn4x .done1,#mermaid-svg-KZGjSKxEjNr5zn4x .done2,#mermaid-svg-KZGjSKxEjNr5zn4x .done3{stroke:grey;fill:lightgrey;stroke-width:2;}#mermaid-svg-KZGjSKxEjNr5zn4x .doneText0,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText1,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText2,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText3{fill:black!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .doneText0.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText0.taskTextOutsideRight,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText1.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText1.taskTextOutsideRight,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText2.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText2.taskTextOutsideRight,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText3.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneText3.taskTextOutsideRight{fill:black!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .crit0,#mermaid-svg-KZGjSKxEjNr5zn4x .crit1,#mermaid-svg-KZGjSKxEjNr5zn4x .crit2,#mermaid-svg-KZGjSKxEjNr5zn4x .crit3{stroke:#ff8888;fill:red;stroke-width:2;}#mermaid-svg-KZGjSKxEjNr5zn4x .activeCrit0,#mermaid-svg-KZGjSKxEjNr5zn4x .activeCrit1,#mermaid-svg-KZGjSKxEjNr5zn4x .activeCrit2,#mermaid-svg-KZGjSKxEjNr5zn4x .activeCrit3{stroke:#ff8888;fill:#bfc7ff;stroke-width:2;}#mermaid-svg-KZGjSKxEjNr5zn4x .doneCrit0,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCrit1,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCrit2,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCrit3{stroke:#ff8888;fill:lightgrey;stroke-width:2;cursor:pointer;shape-rendering:crispEdges;}#mermaid-svg-KZGjSKxEjNr5zn4x .milestone{transform:rotate(45deg) scale(0.8,0.8);}#mermaid-svg-KZGjSKxEjNr5zn4x .milestoneText{font-style:italic;}#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText0,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText1,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText2,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText3{fill:black!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText0.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText0.taskTextOutsideRight,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText1.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText1.taskTextOutsideRight,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText2.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText2.taskTextOutsideRight,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText3.taskTextOutsideLeft,#mermaid-svg-KZGjSKxEjNr5zn4x .doneCritText3.taskTextOutsideRight{fill:black!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .vert{stroke:navy;}#mermaid-svg-KZGjSKxEjNr5zn4x .vertText{font-size:15px;text-anchor:middle;fill:navy!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .activeCritText0,#mermaid-svg-KZGjSKxEjNr5zn4x .activeCritText1,#mermaid-svg-KZGjSKxEjNr5zn4x .activeCritText2,#mermaid-svg-KZGjSKxEjNr5zn4x .activeCritText3{fill:black!important;}#mermaid-svg-KZGjSKxEjNr5zn4x .titleText{text-anchor:middle;font-size:18px;fill:#333;font-family:"trebuchet ms",verdana,arial,sans-serif;}#mermaid-svg-KZGjSKxEjNr5zn4x :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;} 2014-01-07 2014-01-09 2014-01-11 2014-01-13 2014-01-15 2014-01-17 2014-01-19 2014-01-21 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
- 关于 甘特图 语法,参考 这儿,
UML图表
可以使用UML图表进行渲染,例如下面产生的一个序列图:
王五 李四 张三 王五 李四 张三 #mermaid-svg-6qQE2Xl9RUKMGjJ0{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}@keyframes edge-animation-frame{from{stroke-dashoffset:0;}}@keyframes dash{to{stroke-dashoffset:0;}}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-animation-slow{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 50s linear infinite;stroke-linecap:round;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-animation-fast{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 20s linear infinite;stroke-linecap:round;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .error-icon{fill:#552222;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-thickness-normal{stroke-width:1px;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-thickness-invisible{stroke-width:0;fill:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .marker{fill:#333333;stroke:#333333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .marker.cross{stroke:#333333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 p{margin:0;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .actor{stroke:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);fill:#ECECFF;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 text.actor>tspan{fill:black;stroke:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .actor-line{stroke:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .innerArc{stroke-width:1.5;stroke-dasharray:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .messageLine1{stroke-width:1.5;stroke-dasharray:2,2;stroke:#333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 #arrowhead path{fill:#333;stroke:#333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .sequenceNumber{fill:white;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 #sequencenumber{fill:#333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 #crosshead path{fill:#333;stroke:#333;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .messageText{fill:#333;stroke:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .labelBox{stroke:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);fill:#ECECFF;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .labelText,#mermaid-svg-6qQE2Xl9RUKMGjJ0 .labelText>tspan{fill:black;stroke:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .loopText,#mermaid-svg-6qQE2Xl9RUKMGjJ0 .loopText>tspan{fill:black;stroke:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .loopLine{stroke-width:2px;stroke-dasharray:2,2;stroke:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);fill:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .note{stroke:#aaaa33;fill:#fff5ad;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .noteText,#mermaid-svg-6qQE2Xl9RUKMGjJ0 .noteText>tspan{fill:black;stroke:none;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .activation0{fill:#f4f4f4;stroke:#666;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .activation1{fill:#f4f4f4;stroke:#666;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .activation2{fill:#f4f4f4;stroke:#666;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .actorPopupMenu{position:absolute;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .actorPopupMenuPanel{position:absolute;fill:#ECECFF;box-shadow:0px 8px 16px 0px rgba(0,0,0,0.2);filter:drop-shadow(3px 5px 2px rgb(0 0 0 / 0.4));}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .actor-man line{stroke:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);fill:#ECECFF;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 .actor-man circle,#mermaid-svg-6qQE2Xl9RUKMGjJ0 line{stroke:hsl(259.6261682243, 59.7765363128%, 87.9019607843%);fill:#ECECFF;stroke-width:2px;}#mermaid-svg-6qQE2Xl9RUKMGjJ0 :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;} 李四想了很长时间, 文字太长了 不适合放在一行. 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 打量着王五... 很好... 王五, 你怎么样?
- 关于 UML图表 语法,参考 这儿,
流程图
#mermaid-svg-Fg1aqapbvlyDHqPc{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}@keyframes edge-animation-frame{from{stroke-dashoffset:0;}}@keyframes dash{to{stroke-dashoffset:0;}}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-animation-slow{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 50s linear infinite;stroke-linecap:round;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-animation-fast{stroke-dasharray:9,5!important;stroke-dashoffset:900;animation:dash 20s linear infinite;stroke-linecap:round;}#mermaid-svg-Fg1aqapbvlyDHqPc .error-icon{fill:#552222;}#mermaid-svg-Fg1aqapbvlyDHqPc .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-thickness-normal{stroke-width:1px;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-thickness-invisible{stroke-width:0;fill:none;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-Fg1aqapbvlyDHqPc .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-Fg1aqapbvlyDHqPc .marker{fill:#333333;stroke:#333333;}#mermaid-svg-Fg1aqapbvlyDHqPc .marker.cross{stroke:#333333;}#mermaid-svg-Fg1aqapbvlyDHqPc svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-Fg1aqapbvlyDHqPc p{margin:0;}#mermaid-svg-Fg1aqapbvlyDHqPc .label{font-family:"trebuchet ms",verdana,arial,sans-serif;color:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc .cluster-label text{fill:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc .cluster-label span{color:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc .cluster-label span p{background-color:transparent;}#mermaid-svg-Fg1aqapbvlyDHqPc .label text,#mermaid-svg-Fg1aqapbvlyDHqPc span{fill:#333;color:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc .node rect,#mermaid-svg-Fg1aqapbvlyDHqPc .node circle,#mermaid-svg-Fg1aqapbvlyDHqPc .node ellipse,#mermaid-svg-Fg1aqapbvlyDHqPc .node polygon,#mermaid-svg-Fg1aqapbvlyDHqPc .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-Fg1aqapbvlyDHqPc .rough-node .label text,#mermaid-svg-Fg1aqapbvlyDHqPc .node .label text,#mermaid-svg-Fg1aqapbvlyDHqPc .image-shape .label,#mermaid-svg-Fg1aqapbvlyDHqPc .icon-shape .label{text-anchor:middle;}#mermaid-svg-Fg1aqapbvlyDHqPc .node .katex path{fill:#000;stroke:#000;stroke-width:1px;}#mermaid-svg-Fg1aqapbvlyDHqPc .rough-node .label,#mermaid-svg-Fg1aqapbvlyDHqPc .node .label,#mermaid-svg-Fg1aqapbvlyDHqPc .image-shape .label,#mermaid-svg-Fg1aqapbvlyDHqPc .icon-shape .label{text-align:center;}#mermaid-svg-Fg1aqapbvlyDHqPc .node.clickable{cursor:pointer;}#mermaid-svg-Fg1aqapbvlyDHqPc .root .anchor path{fill:#333333!important;stroke-width:0;stroke:#333333;}#mermaid-svg-Fg1aqapbvlyDHqPc .arrowheadPath{fill:#333333;}#mermaid-svg-Fg1aqapbvlyDHqPc .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-Fg1aqapbvlyDHqPc .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-Fg1aqapbvlyDHqPc .edgeLabel{background-color:rgba(232,232,232, 0.8);text-align:center;}#mermaid-svg-Fg1aqapbvlyDHqPc .edgeLabel p{background-color:rgba(232,232,232, 0.8);}#mermaid-svg-Fg1aqapbvlyDHqPc .edgeLabel rect{opacity:0.5;background-color:rgba(232,232,232, 0.8);fill:rgba(232,232,232, 0.8);}#mermaid-svg-Fg1aqapbvlyDHqPc .labelBkg{background-color:rgba(232, 232, 232, 0.5);}#mermaid-svg-Fg1aqapbvlyDHqPc .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-Fg1aqapbvlyDHqPc .cluster text{fill:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc .cluster span{color:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-Fg1aqapbvlyDHqPc .flowchartTitleText{text-anchor:middle;font-size:18px;fill:#333;}#mermaid-svg-Fg1aqapbvlyDHqPc rect.text{fill:none;stroke-width:0;}#mermaid-svg-Fg1aqapbvlyDHqPc .icon-shape,#mermaid-svg-Fg1aqapbvlyDHqPc .image-shape{background-color:rgba(232,232,232, 0.8);text-align:center;}#mermaid-svg-Fg1aqapbvlyDHqPc .icon-shape p,#mermaid-svg-Fg1aqapbvlyDHqPc .image-shape p{background-color:rgba(232,232,232, 0.8);padding:2px;}#mermaid-svg-Fg1aqapbvlyDHqPc .icon-shape .label rect,#mermaid-svg-Fg1aqapbvlyDHqPc .image-shape .label rect{opacity:0.5;background-color:rgba(232,232,232, 0.8);fill:rgba(232,232,232, 0.8);}#mermaid-svg-Fg1aqapbvlyDHqPc .label-icon{display:inline-block;height:1em;overflow:visible;vertical-align:-0.125em;}#mermaid-svg-Fg1aqapbvlyDHqPc .node .label-icon path{fill:currentColor;stroke:revert;stroke-width:revert;}#mermaid-svg-Fg1aqapbvlyDHqPc :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;} 链接
长方形
圆
圆角长方形
菱形
- 关于 Mermaid 语法,参考 这儿,
FLowchart流程图
我们依旧会支持flowchart.js的流程图语法:
Created with Raphaël 2.3.0 开始 我的操作 确认? 结束 yes no
- 关于 Flowchart流程图 语法,参考 这儿.
导出与导入
导出
如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。
导入
如果你想加载一篇你写过的.md文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。
-
注脚的解释 ↩︎
*[HTML]: 超文本标记语言