Mermaid quick start
Mermaid diagrams stream progressively in markstream-vue: as soon as the syntax becomes valid the chart renders, then refines as more tokens arrive. This page covers setup, a streaming example, and common fixes.
1. Install & import
pnpm add mermaidKeep the CSS import after your reset and inside @layer components when using Tailwind/UnoCSS so utility layers do not override Mermaid styles.
@import 'modern-css-reset';
@layer components {
@import 'markstream-vue/index.css';
}2. Streaming example
Mermaid renders as soon as the snippet is syntactically valid. The snippet below shows a gradual update (ideal for AI responses or long-running tasks):
<script setup lang="ts">
import MarkdownRender from 'markstream-vue'
import { ref } from 'vue'
const content = ref('')
const steps = [
'```mermaid\n',
'graph TD\n',
'A[Start]-->B{Is valid?}\n',
'B -- Yes --> C[Render]\n',
'B -- No --> D[Wait]\n',
'```\n',
]
let i = 0
const id = setInterval(() => {
content.value += steps[i] || ''
i++
if (i >= steps.length)
clearInterval(id)
}, 120)
</script>
<template>
<MarkdownRender :content="content" />
<!-- Diagram progressively appears as content streams in -->
</template>Quick try — paste this Markdown into a page or component:
\`\`\`mermaid
graph LR
A[Start]-->B
B-->C[End]
\`\`\`3. Advanced component: MermaidBlockNode
Need header controls, export buttons, or a pseudo-fullscreen modal? Use MermaidBlockNode or override the default renderer via setCustomComponents. A runnable playground demo lives at /mermaid-export-demo. If diagrams come from untrusted users/LLMs, pass :is-strict="true" to enable Mermaid's strict mode and SVG sanitization so injected HTML/event handlers are stripped before render.
4. Troubleshooting checklist
- Peer not installed — run
pnpm add mermaid. Without it the renderer falls back to showing source text. - CSS missing — import
mermaid/dist/mermaid.cssafter your reset (and wrap it in@layer componentswhen Tailwind/UnoCSS is present). Missing CSS manifests as invisible diagrams. - Async errors — check the browser console for Mermaid logs. Versions prior to 11 are unsupported; upgrade to ≥ 11.
- SSR guard — Mermaid needs the DOM. Wrap the component in
<ClientOnly>for Nuxt or checktypeof window !== 'undefined'before mounting in SSR contexts. - Heavy graphs — consider pre-rendering server-side (mermaid CLI) or caching SVG output; the component exposes
svgStringwhen usingMermaidBlockNodeexport events.
Still stuck? Reproduce the issue in the playground (pnpm play) with a minimal Markdown sample and link it when opening a bug report.
CDN usage (no bundler)
If you load Mermaid via CDN and want progressive off-main-thread parsing, inject a CDN-backed worker:
import { createMermaidWorkerFromCDN, enableMermaid, setMermaidLoader, setMermaidWorker } from 'markstream-vue'
// use the CDN global (UMD) on the main thread
setMermaidLoader(() => (window as any).mermaid)
enableMermaid(() => (window as any).mermaid)
// optional: worker used for parse/prefix checks during streaming
const { worker } = createMermaidWorkerFromCDN({
mode: 'module',
mermaidUrl: 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs',
})
if (worker)
setMermaidWorker(worker)