TypeScript 支持
Docusaurus 由 TypeScript 写成,并提供一流的 TypeScript 支持。
初始化
Docusaurus 支持编写和使用 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 create-docusaurus@latest my-website classic --typescript
下面是一些关于如何将现有项目迁移到 TypeScript 的指南。
设置
To start using TypeScript, add @docusaurus/module-type-aliases and the base TS config to your project:
- npm
- Yarn
- pnpm
- Bun
npm install --save-dev typescript @docusaurus/module-type-aliases @tsconfig/docusaurus
yarn add --dev typescript @docusaurus/module-type-aliases @tsconfig/docusaurus
pnpm add --save-dev typescript @docusaurus/module-type-aliases @tsconfig/docusaurus
bun add --dev typescript @docusaurus/module-type-aliases @tsconfig/docusaurus
随后在你的项目根目录的 tsconfig.json 中添加如下内容:
{
"extends": "@tsconfig/docusaurus/tsconfig.json",
"compilerOptions": {
"baseUrl": "."
}
}
Docusaurus 不会用这个 tsconfig.json 来编译你的项目。 这只是为了改善你的编辑体验。不过你也可以选择自己在本地或在 CI 上运行 tsc 来对你的代码做类型检查。
现在,你可以开始撰写 TypeScript 主题组件了。
为配置文件添加类型
It is not possible to use a TypeScript config file in Docusaurus unless you compile it yourself to JavaScript.
We recommend using JSDoc type annotations:
// @ts-check
/** @type {import('@docusaurus/types').Plugin} */
function MyPlugin(context, options) {
return {
name: 'my-plugin',
};
}
/** @type {import('@docusaurus/types').Config} */
const config = {
title: 'Docusaurus',
tagline: 'Build optimized websites quickly, focus on your content',
organizationName: 'facebook',
projectName: 'docusaurus',
plugins: [MyPlugin],
presets: [
[
'@docusaurus/preset-classic',
/** @type {import('@docusaurus/preset-classic').Options} */
({
docs: {
path: 'docs',
sidebarPath: 'sidebars.js',
},
blog: {
path: 'blog',
postsPerPage: 5,
},
}),
],
],
themeConfig:
/** @type {import('@docusaurus/preset-classic').ThemeConfig} */
({
colorMode: {
defaultMode: 'dark',
},
navbar: {
hideOnScroll: true,
title: 'Docusaurus',
logo: {
alt: 'Docusaurus Logo',
src: 'img/docusaurus.svg',
srcDark: 'img/docusaurus_keytar.svg',
},
},
}),
};
module.exports = config;
类型注解非常有用,它能够帮助你的编辑器理解配置对象的类型!
最好的 IDE(VS Code,WebStorm,IntellliJ……) 会提供一个非常棒的自动补全体验。
默认情况下,Docusaurus TypeScript 配置不会对 JavaScript 文件进行类型检查。
// @ts-check 注释会确保在运行 npx tsc 时,配置文件可以被类型检查。
Swizzle TypeScript 主题组件
对于支持 TypeScript 的主题组件,你可以在 swizzle 命令末尾添加 --typescript 参数,以获取 TypeScript 源码。 举个例子,下列代码会在 src/theme/Footer 中生成 index.tsx 和 styles.module.css。
- npm
- Yarn
- pnpm
- Bun
npm run swizzle @docusaurus/theme-classic Footer -- --typescript
yarn swizzle @docusaurus/theme-classic Footer --typescript
pnpm run swizzle @docusaurus/theme-classic Footer --typescript
bun run swizzle @docusaurus/theme-classic Footer --typescript
All official Docusaurus themes support TypeScript theme components, including theme-classic, theme-live-codeblock, and theme-search-algolia. If you are a Docusaurus theme package author who wants to add TypeScript support, see the Lifecycle APIs docs.