TypeDoc requires Node.js to run. It supports the current LTS version or newer. It can be installed either locally to your project or globally.
If you install globally, be aware that npm/cli#7057
means that plugins and themes will get their own installation of TypeDoc unless you use the
--legacy-peer-deps
flag. This will break many plugins and cause warnings from TypeDoc.
TypeDoc aims to support the two latest TypeScript releases for the current release. Depending on the scale of breaking changes introduced in a new TypeScript version, a given version may support more versions of TypeScript. TypeDoc may work with older (or newer) TypeScript versions, but the supported version range will generally not include versions not supported by DefinitelyTyped.
TypeDoc Version | TypeScript Version | Status |
---|---|---|
0.27 | 5.0 through 5.7 | ✅ Maintained |
0.26 | 4.6 through 5.6 | ⚠️ Security Updates |
0.25 | 4.6 through 5.4 | ❌ Unmaintained |
0.24 | 4.6 through 5.1 | ❌ Unmaintained |
0.23 | 4.6 through 5.0 | ❌ Unmaintained |
0.22 | 4.0 through 4.7 | ❌ Unmaintained |
0.21 | 4.0 through 4.4 | ❌ Unmaintained |
0.20 | 3.9 through 4.2 | ❌ Unmaintained |
0.19 | 3.9 through 4.0 | ❌ Unmaintained |
TypeDoc's CLI can be used through your terminal or npm scripts. Any arguments passed to TypeDoc which are not flags are parsed as entry points. TypeDoc will also read configuration from several files. See Configuration for details on where options are read from.
typedoc --help
typedoc path/to/entry.ts
Options:
--alwaysCreateEntryPointModule When set, TypeDoc will always create a `Module` for entry points, even if only one is provided
--basePath Specifies the base path to be used when displaying file paths
--blockTags Block tags which TypeDoc should recognize when parsing comments
--cacheBust Include the generation time in links to static assets
--cascadedModifierTags Modifier tags which TypeDoc should recognize when parsing comments
--categorizeByGroup Specify whether categorization will be done at the group level
--categoryOrder Specify the order in which categories appear. * indicates the relative order for categories not in the list
--cleanOutputDir If set, TypeDoc will remove the output directory before writing output
--cname Set the CNAME file text, it's useful for custom domains on GitHub Pages
--commentStyle Determines how TypeDoc searches for comments
--customCss Path to a custom CSS file to for the theme to import
--customFooterHtml Custom footer after the TypeDoc link
--customFooterHtmlDisableWrapper If set, disables the wrapper element for customFooterHtml
--customJs Path to a custom JS file to import
--darkHighlightTheme Specify the code highlighting theme in dark mode
--defaultCategory Specify the default category for reflections without a category
--disableGit Assume that all can be linked to with the sourceLinkTemplate, sourceLinkTemplate must be set if this is enabled. {path} will be rooted at basePath
--disableSources Disable setting the source of a reflection when documenting it
--emit Specify what TypeDoc should emit, 'docs', 'both', or 'none'
--entryPoints The entry points of your documentation
--entryPointStrategy The strategy to be used to convert entry points into documentation modules
--exclude Define patterns to be excluded when expanding a directory that was specified as an entry point
--excludeCategories Exclude symbols within this category from the documentation
--excludeExternals Prevent externally resolved symbols from being documented
--excludeInternal Prevent symbols that are marked with @internal from being documented
--excludeNotDocumented Prevent symbols that are not explicitly documented from appearing in the results
--excludeNotDocumentedKinds Specify the type of reflections that can be removed by excludeNotDocumented
--excludePrivate Ignore private variables and methods, defaults to true.
--excludeProtected Ignore protected variables and methods
--excludeReferences If a symbol is exported multiple times, ignore all but the first export
--excludeTags Remove the listed block/modifier tags from doc comments
--externalPattern Define patterns for files that should be considered being external
--externalSymbolLinkMappings Define custom links for symbols not included in the documentation
--favicon Path to favicon to include as the site icon
--githubPages Generate a .nojekyll file to prevent 404 errors in GitHub Pages. Defaults to `true`
--gitRemote Use the specified remote for linking to GitHub/Bitbucket source files. Has no effect if disableGit or disableSources is set
--gitRevision Use specified revision instead of the last revision for linking to GitHub/Bitbucket source files. Has no effect if disableSources is set
--groupOrder Specify the order in which groups appear. * indicates the relative order for groups not in the list
--groupReferencesByType If set, references will be grouped with the type they refer to rather than in a 'References' group
--headings Determines which optional headings are rendered
--help Print this message
--hideGenerator Do not print the TypeDoc link at the end of the page
--highlightLanguages Specify the languages which will be loaded to highlight code when rendering
--hostedBaseUrl Specify a base URL to be used in generating a sitemap.xml in our output folder and canonical links. If not specified, no sitemap will be generated
--html Specify the location where html documentation should be written to.
--ignoredHighlightLanguages Specify languages which will be accepted as valid highlight languages, but will not be highlighted at runtime
--includeHierarchySummary If set, a reflections hierarchy summary will be rendered to a summary page. Defaults to `true`
--includeVersion Add the package version to the project name
--inlineTags Inline tags which TypeDoc should recognize when parsing comments
--intentionallyNotExported A list of types which should not produce 'referenced but not documented' warnings
--jsDocCompatibility Sets compatibility options for comment parsing that increase similarity with JSDoc comments
--json Specify the location and filename a JSON file describing the project is written to
--kindSortOrder Specify the sort order for reflections when 'kind' is specified
--lang Sets the language to be used in generation and in TypeDoc's messages
--lightHighlightTheme Specify the code highlighting theme in light mode
--logLevel Specify what level of logging should be used
--markdownLinkExternal Specifies that http[s]:// links in comments and markdown files should be treated as external links to be opened in a new tab
--maxTypeConversionDepth Set the maximum depth of types to be converted
--modifierTags Modifier tags which TypeDoc should recognize when parsing comments
--name Set the name of the project that will be used in the header of the template
--navigation Determines how the navigation sidebar is organized
--navigationLeaves Branches of the navigation tree which should not be expanded
--navigationLinks Defines links to be included in the header
--notRenderedTags Tags which will be preserved in doc comments, but not rendered when creating output
--options Specify a json option file that should be loaded. If not specified TypeDoc will look for 'typedoc.json' in the current directory
--out Specify the location the documentation for the default output should be written to. The default output type may be changed by plugins.
--plugin Specify the npm plugins that should be loaded. Omit to load all installed plugins
--preserveLinkText If set, @link tags without link text will use the text content as the link. If not set, will use the target reflection name
--preserveWatchOutput If set, TypeDoc will not clear the screen between compilation runs
--pretty Specify whether the output JSON should be formatted with tabs
--projectDocuments Documents which should be added as children to the root of the generated documentation. Supports globs to match multiple files
--readme Path to the readme file that should be displayed on the index page. Pass `none` to disable the index page and start the documentation on the globals page
--requiredToBeDocumented A list of reflection kinds that must be documented
--searchInComments If set, the search index will also include comments. This will greatly increase the size of the search index
--searchInDocuments If set, the search index will also include documents. This will greatly increase the size of the search index
--showConfig Print the resolved configuration and exit
--sidebarLinks Defines links to be included in the sidebar
--skipErrorChecking Do not run TypeScript's type checking before generating docs
--sluggerConfiguration Determines how anchors within rendered HTML are determined.
--sort Specify the sort strategy for documented values
--sortEntryPoints If set, entry points will be subject to the same sorting rules as other reflections
--sourceLinkExternal Specifies that source links should be treated as external links to be opened in a new tab
--sourceLinkTemplate Specify a link template to be used when generating source urls. If not set, will be automatically created using the git remote. Supports {path}, {line}, {gitRevision} placeholders
--suppressCommentWarningsInDeclarationFiles Sets the language to be used in generation and in TypeDoc's messages
--theme Specify the theme name to render the documentation with
--titleLink Set the link the title in the header points to. Defaults to the documentation homepage
--treatValidationWarningsAsErrors If set, warnings emitted during validation will be treated as errors. This option cannot be used to disable treatWarningsAsErrors for validation warnings
--treatWarningsAsErrors If set, all warnings will be treated as errors
--tsconfig Specify a TypeScript config file that should be loaded. If not specified TypeDoc will look for 'tsconfig.json' in the current directory
--typePrintWidth Width at which to wrap code to a new line when rendering a type
--useFirstParagraphOfCommentAsSummary If set and no @summary tag is specified, TypeDoc will use the first paragraph of comments as the short summary in the module/namespace view
--useHostedBaseUrlForAbsoluteLinks If set, TypeDoc will produce absolute links to pages on your site using the hostedBaseUrl option
--useTsLinkResolution Use TypeScript's link resolution when determining where @link tags point. This only applies to JSDoc style comments
--validation Specify which validation steps TypeDoc should perform on your generated documentation
--version Print TypeDoc's version
--watch Watch files for changes and rebuild docs on change
Supported highlighting languages:
1c 1c-query abap actionscript-3
ada adoc angular-html angular-ts
apache apex apl applescript
ara asciidoc asm astro
awk ballerina bash bat
batch be beancount berry
bibtex bicep blade bsl
c c# c++ cadence
cairo cdc clarity clj
clojure closure-templates cmake cmd
cobol codeowners codeql coffee
coffeescript common-lisp console coq
cpp cql crystal cs
csharp css csv cue
cypher d dart dax
desktop diff docker dockerfile
dotenv dream-maker edge elisp
elixir elm emacs-lisp erb
erl erlang f f#
f03 f08 f18 f77
f90 f95 fennel fish
fluent for fortran-fixed-form fortran-free-form
fs fsharp fsl ftl
gdresource gdscript gdshader genie
gherkin git-commit git-rebase gjs
gleam glimmer-js glimmer-ts glsl
gnuplot go gql graphql
groovy gts hack haml
handlebars haskell haxe hbs
hcl hjson hlsl hs
html html-derivative http hxml
hy imba ini jade
java javascript jinja jison
jl js json json5
jsonc jsonl jsonnet jssm
jsx julia kotlin kql
kt kts kusto latex
lean lean4 less liquid
lisp lit log logo
lua luau make makefile
markdown marko matlab md
mdc mdx mediawiki mermaid
mips mipsasm mmd mojo
move nar narrat nextflow
nf nginx nim nix
nu nushell objc objective-c
objective-cpp ocaml pascal perl
perl6 php plsql po
postcss pot potx powerquery
powershell prisma prolog properties
proto protobuf ps ps1
pug puppet purescript py
python ql qml qmldir
qss r racket raku
razor rb reg regex
regexp rel riscv rs
rst ruby rust sas
sass scala scheme scss
sdbl sh shader shaderlab
shell shellscript shellsession smalltalk
solidity soy sparql spl
splunk sql ssh-config stata
styl stylus svelte swift
system-verilog systemd talon talonscript
tasl tcl templ terraform
tex text tf tfvars
toml ts ts-tags tsp
tsv tsx turtle twig
txt typ typescript typespec
typst v vala vb
verilog vhdl vim viml
vimscript vue vue-html vy
vyper wasm wenyan wgsl
wiki wikitext wl wolfram
xml xsl yaml yml
zenscript zig zsh 文言
Supported highlighting themes:
andromeeda aurora-x
ayu-dark catppuccin-frappe
catppuccin-latte catppuccin-macchiato
catppuccin-mocha dark-plus
dracula dracula-soft
everforest-dark everforest-light
github-dark github-dark-default
github-dark-dimmed github-dark-high-contrast
github-light github-light-default
github-light-high-contrast houston
kanagawa-dragon kanagawa-lotus
kanagawa-wave laserwave
light-plus material-theme
material-theme-darker material-theme-lighter
material-theme-ocean material-theme-palenight
min-dark min-light
monokai night-owl
nord one-dark-pro
one-light plastic
poimandres red
rose-pine rose-pine-dawn
rose-pine-moon slack-dark
slack-ochin snazzy-light
solarized-dark solarized-light
synthwave-84 tokyo-night
vesper vitesse-black
vitesse-dark vitesse-light
TypeDoc exposes an API which can be used to run it without any configuration files.
import * as td from "typedoc";
// Application.bootstrap also exists, which will not load plugins
// Also accepts an array of option readers if you want to disable
// TypeDoc's tsconfig.json/package.json/typedoc.json option readers
const app = await td.Application.bootstrapWithPlugins({
entryPoints: ["src/index.ts"],
});
// May be undefined if errors are encountered.
const project = await app.convert();
if (project) {
const outputDir = "docs";
// Generate HTML rendered docs
await app.generateDocs(project, outputDir);
// Alternatively generate JSON output
await app.generateJson(project, outputDir + "/docs.json");
}