External Markdown
It can be convenient to write long-form guides/tutorials outside of doc comments.
To support this, TypeDoc supports including documents which exist as standalone
.md
files in your repository.
Including Documents
These documents can be included in your generated documentation in a few ways.
- With the
@document
tag. - With the projectDocuments option.
- As a child of another document using yaml frontmatter.
The @document
Tag
The @document
tag can be placed in the comments for most types to add
a child to that reflection in the generated documentation. The content of
the @document
tag should simply be a path to a markdown document to be
included in the site.
/**
* @document documents/external-markdown.md
*/
The document path is relative to the file in which the comment appears in.
Project Documents
If your project has multiple entry points, the @document
tag cannot be used
to place documents at the top level of the project as there is no comment location
associated with the project. For this use case, specify the projectDocuments
option. This option can be specified multiple times, or a glob may be specified
to include multiple documents.
// typedoc.json
{
"projectDocuments": ["documents/*.md"]
}
TypeDoc's default sorting options will cause project documents to be re-ordered alphabetically. If not desired, sorting for entry points can be disabled with the sortEntryPoints option.
Document Content
Documents may include a yaml frontmatter section which can be used to control
some details about the document. Note: The frontmatter must begin and end with
---
on lines by itself. TypeDoc's frontmatter extraction uses this to determine
when the block ends.
---
title: External Markdown
group: Documents
category: Guides
children:
- ./child.md
- ./child2.md
---
The title
key specifies the document name, which will be used in the sidebar
navigation. The group
and category
keys are equivalent to the
@group
and @category
tags and control how the document shows up in the Index section on the page
for the reflection which owns the document. The children
key can be used to specify
additional documents which should be added underneath the current document.
Documents may include relative links to images or other files/documents. TypeDoc
will detect links within markdown [text](link)
formatted links, <a>
tags
and <img>
tags and automatically resolve them to other documents in the project.
if a path cannot be resolved to a part of the documentation, TypeDoc will copy
the file found to a media
folder in your generated documentation and update the
link to point to it, so relative links to images will still work.
Documents may also include {@link}
inline tags, which will be resolved as
declaration references by
TypeDoc.