TypeScript 支持
Docusaurus is written in TypeScript, and provide first-class TypeScript support.
#
InitializationDocusaurus 支持编写和使用 TypeScript 主题组件。 If the init template provides a Typescript variant, you can directly initialize a site with full TypeScript support by using the --typescript
flag.
npx @docusaurus/init@latest init my-website classic --typescript
Below are some guides on how to migrate an existing project to TypeScript.
#
设置要开始使用 TypeScript,请将 @docusaurus/module-type-aliases
和一些 @types
依赖关系添加到您的项目:
- npm
- Yarn
npm install --save-dev typescript @docusaurus/module-type-aliases @types/react @types/react-router-dom @types/react-helmet @tsconfig/docusaurus
yarn add --dev typescript @docusaurus/module-type-aliases @types/react @types/react-router-dom @types/react-helmet @tsconfig/docusaurus
随后将以下内容添加到您的项目根目录的 tsconfig.json
:
{ "extends": "@tsconfig/docusaurus/tsconfig.json", "include": ["src/"]}
Docusaurus 不会使用此 tsconfig.json
来编译您的项目。 这只是为了改善您的编辑体验,虽然您也可以选择自己或在持续集成上运行 tsc
来类型检查您的代码。
现在,您可以开始撰写 TypeScript 主题组件了。
#
Typing the config fileIt is not possible to use a TypeScript config file in Docusaurus, unless you compile it yourself to JavaScript.
We recommend using JSDoc type annotations:
/** @type {import('@docusaurus/types').Plugin} */function MyPlugin(context, options) { return { name: 'my-plugin', };}
/** @type {import('@docusaurus/types').DocusaurusConfig} */const config = { title: 'Docusaurus', tagline: 'Build optimized websites quickly, focus on your content', organizationName: 'facebook', projectName: 'docusaurus', plugins: [MyPlugin],};
module.exports = config;
tip
Type annotations are very useful and help your IDE understand the type of config objects!
The best IDEs (VSCode, WebStorm, Intellij...) will provide a nice auto-completion experience.
#
变换 TypeScript 主题组件对于支持 TypeScript 的主题组件,您可于变换(Swizzling)命令末尾添加 --typescript
参数以获取 TypeScript 源代码。 举个例子,下列代码将生成 index.tsx
及 styles.module.css
至 src/theme/Footer
。
- npm
- Yarn
npm run swizzle @docusaurus/theme-classic Footer -- --typescript
yarn run swizzle @docusaurus/theme-classic Footer -- --typescript
迄今为止,支持 TypeScript 主题组件的唯一 Docusaurus 官方主题是 @docusaurus/theme-classic
。 如果您是一位 Docusaurus 主题作者,且想要添加 TypeScript 支持,请参阅生命周期 API 文档。