mdast utility to get the vue vnode
This package is a utility that takes mdast input and turns it into an Vue.js VNode.
Tip
Vue Markdown: the vue component for render markdown string, and support streaming for AI. Learn more 👉
If you want to use Vue.js to render mdast, use it. It is especially useful when you want to render streamed MarkDown strings in AI application development.
npm install mdast-util-to-vnodeSay we have the following markdown file example.md:
# Heading
`mdast-util-to-vnode` is a mdast utility to get the vue vnode.And our module example.js looks as follows:
import fs from 'node:fs/promises'
import { fromMarkdown } from 'mdast-util-from-markdown'
import { toVNode } from 'mdast-util-to-vnode'
const doc = await fs.readFile('example.md')
const vnode = toVNode(fromMarkdown(doc))
console.log(vnode)Now running node example.js yields (some info removed for brevity):
{
  "type": "div",
  "props": null,
  "key": null,
  "children": [
    {
      "type": "h1",
      "props": null,
      "key": null,
      "children": [
        {
          "props": null,
          "key": null,
          "children": "Heading"
        }
      ]
    },
    {
      "type": "p",
      "props": null,
      "key": null,
      "children": [
        {
          "type": "code",
          "props": null,
          "key": null,
          "children": "mdast-util-to-vnode"
        },
        {
          "props": null,
          "key": null,
          "children": " is a mdast utility to get the vue vnode."
        }
      ]
    }
  ]
}This package exports the identifier toVNode. There is no default export.
Support passing in custom Vue components to override mdast nodes.
export type ComponentReturn = Component | [Component, Record<string, any> | undefined]
export interface ToVNodeOptions {
  components?: Partial<Record<Nodes['type'], ComponentReturn |
  ((node: Node) => ComponentReturn)>>
}