Skip to content
...

组件 Props 与选项

在集成 markstream-vue 时,常会需要微调流式行为、控制重节点渲染或避免 Tailwind/UnoCSS 样式冲突。本页提供对照表与排障提示。

MarkdownRender 核心 props

Prop类型默认值说明
contentstring原始 Markdown 字符串(除非提供 nodes,否则必填)。
nodesBaseNode[]预解析后的 AST(通常为 parseMarkdownToStructure 返回的 ParsedNode[])。
custom-idstring作用域键,可在 setCustomComponents 注册映射并用 [data-custom-id="docs"] 做样式覆盖。
is-darkbooleanfalse主题标记,会透传给 Mermaid/D2/KaTeX/CodeBlock,并在根容器上添加 .dark
index-keynumber | string内部节点 key 前缀;嵌套渲染或列表中渲染多实例时建议显式传入。
finalbooleanfalse是否为“流结束/最终态”。开启后会关闭解析器的中间态(loading)行为,避免末尾残留分隔符(如 $$、未闭合 code fence)永远停留在 loading。
parse-optionsParseOptionsToken 级钩子(preTransformTokenspostTransformTokens),仅在传入 content 时生效。
custom-html-tagsstring[]扩展流式内联 HTML 中间态白名单,并将这些标签直接输出为自定义节点(如 type: 'thinking')以便 setCustomComponents 映射(会传给 getMarkdown,如 ['thinking'])。
custom-markdown-it(md: MarkdownIt) => MarkdownIt自定义内部 MarkdownIt 实例(加插件、改配置)。
debug-performancebooleanfalse打印解析/渲染耗时与虚拟化统计(仅 dev)。
typewriterbooleantrue控制轻量进入动画。生成静态截图或 SSR 输出时可关闭。

流式与重节点开关

Flag默认值功能
render-code-blocks-as-prefalse将非 Mermaid/Infographic/D2 的 code_block 渲染为 <pre><code>,适合仅查看或排查 Monaco/Tailwind 样式问题。Mermaid/infographic/D2 仍会路由到各自组件,除非用 setCustomComponents 覆盖。
code-block-streamtrue启用流式代码块更新;关闭后会保持加载态直到完整文本就绪,避免频繁初始化 Monaco。
viewport-prioritytrue优先渲染视窗内的 Mermaid/D2/Monaco/KaTeX 等重节点,延迟离屏渲染以提升交互体验。
defer-nodes-until-visibletrue启用后,重节点在接近视口前可先渲染为占位(仅在非虚拟化模式生效)。

渲染性能(虚拟化 & 分批渲染)

Prop默认值说明
max-live-nodes320虚拟化阈值;设为 0 可关闭虚拟化(全部渲染)。
live-node-buffer60视窗前后保留的节点数量(overscan)。
batch-renderingtrue分批渲染(仅当 max-live-nodes <= 0 时启用)。
initial-render-batch-size40初始立即渲染的节点数。
render-batch-size80每批渲染的节点数。
render-batch-delay16每批在 rAF 之后额外延迟(ms)。
render-batch-budget-ms6单批预算(ms),超过后会自适应缩小后续 batch。
render-batch-idle-timeout-ms120requestIdleCallback 切片的超时(ms,若可用)。

代码块全局选项(由 MarkdownRender 下发)

这些 props 会被转发到 CodeBlockNode / MarkdownCodeBlockNode(但 不会 转发到 Mermaid/D2/Infographic 代码块,因为它们会路由到各自组件):

  • code-block-dark-theme, code-block-light-theme
  • code-block-monaco-options
  • code-block-min-width, code-block-max-width
  • code-block-props(兜底:转发任意 CodeBlock props)
  • themes(在安装 stream-monaco 时,会转发给其主题系统)

注意:code-block-monaco-options 仅作用于 Monaco 版 CodeBlockNode。如果你把 code_block 覆盖成 MarkdownCodeBlockNode,此时 code-block-dark-theme / code-block-light-theme 应填写 Shiki 主题名,themes 为需要预加载的 Shiki 主题列表。

图表节点全局下发参数

如果你希望统一控制 Mermaid / D2 / Infographic 的工具栏、渐进渲染参数或交互细节,而不手动覆盖组件,可直接在 MarkdownRender 上传这些对象:

  • mermaid-props:透传给 MermaidBlockNode
  • d2-props:透传给 D2BlockNode
  • infographic-props:透传给 InfographicBlockNode

示例:

vue
<MarkdownRender
  :content="md"
  :mermaid-props="{ showHeader: false, renderDebounceMs: 180, previewPollDelayMs: 500 }"
  :d2-props="{ progressiveIntervalMs: 450, showCopyButton: false }"
/>

其中 mermaid-props 很适合用于流式调优,常用项包括:

  • renderDebounceMs
  • contentStableDelayMs
  • previewPollDelayMs
  • previewPollMaxDelayMs
  • previewPollMaxAttempts
  • showHeadershowModeToggleshowExportButtonshowZoomControls 等工具栏开关

代码块头部控制

可直接传给 CodeBlockNode / MarkdownCodeBlockNode / MermaidBlockNode,或在 MarkdownRender 上用 code-block-props 统一下发:

  • show-header
  • show-copy-button
  • show-expand-button
  • show-preview-button
  • show-collapse-button
  • show-font-size-buttons
  • show-tooltips(全局控制 LinkNode + 代码块节点的 tooltip + Mermaid块节点的 tooltip)

更多细节请参考 /zh/guide/codeblock-header 及类型定义。

示例(全局默认):

vue
<template>
  <MarkdownRender
    :content="md"
    :code-block-props="{ showHeader: false, showFontSizeButtons: false }"
  />
</template>

示例

vue
<script setup lang="ts">
import MarkdownRender from 'markstream-vue'

const md = '# 标题\n\n演示 props 用法。'
</script>

<template>
  <MarkdownRender
    :content="md"
    custom-id="docs"
    :viewport-priority="true"
    :code-block-stream="true"
  />
</template>

样式与排障提示

  1. 先引入 resetmodern-css-reset@tailwind base@unocss/reset),再在 @layer components 中导入 markstream-vue/index.css,避免被 utilities 覆盖。详见 Tailwind 指南
  2. 使用 custom-id[data-custom-id="docs"] 限定覆盖范围。
  3. 检查同伴 CSS 是否导入(KaTeX),Mermaid/D2 不需要额外 CSS。
  4. 查阅 样式排查清单,确保 reset、layer、Uno/Tailwind 配置正确。