From e1199b8a5e43da2b8227824c66fef8b9677bf032 Mon Sep 17 00:00:00 2001 From: 10Derozan Date: Tue, 20 Feb 2024 16:09:29 +0800 Subject: [PATCH] docs(react-docgen): add some limit and more info (#5409) --- .../docs/en/guide/basic/use-module-doc.mdx | 21 +++++++++++++++++- .../docs/zh/guide/basic/use-module-doc.mdx | 22 +++++++++++++++++-- 2 files changed, 40 insertions(+), 3 deletions(-) diff --git a/packages/document/module-doc/docs/en/guide/basic/use-module-doc.mdx b/packages/document/module-doc/docs/en/guide/basic/use-module-doc.mdx index cab6789e7dcd..10bc6a5020fc 100644 --- a/packages/document/module-doc/docs/en/guide/basic/use-module-doc.mdx +++ b/packages/document/module-doc/docs/en/guide/basic/use-module-doc.mdx @@ -245,7 +245,20 @@ export const Button = (props?: ButtonProps) => {}; ``` The above is a standard writeup where `ButtonProps` will be extracted into the table and `Button` will be the title of the table. -If you use the default export, the filename will be used as the form title. The generated content is as follows: +If you use the default export, the filename will be used as the form title. + +Notice that export features declared elsewhere are not available. + +```tsx +const A = () => {}; + +export { A }; // wrong +export default A; // wrong +export const B = () => {}; // right +export default () => {}; // right +``` + +The generated content is as follows: ```mdx ### ButtonTest @@ -267,6 +280,12 @@ If React types are used in Props, you need to add the types in tsconfig.json, ot } ``` +The best way is that you import the type directly: + +```tsx +import { FC } from 'react'; +``` + ::: - `documentation` is used in tool library scenarios to parse JSDoc annotations. diff --git a/packages/document/module-doc/docs/zh/guide/basic/use-module-doc.mdx b/packages/document/module-doc/docs/zh/guide/basic/use-module-doc.mdx index 2d3baa1d95d0..640efe5d57fb 100644 --- a/packages/document/module-doc/docs/zh/guide/basic/use-module-doc.mdx +++ b/packages/document/module-doc/docs/zh/guide/basic/use-module-doc.mdx @@ -239,8 +239,20 @@ export type ButtonProps = { export const Button = (props?: ButtonProps) => {}; ``` -上面是一个标准写法,其中 `ButtonProps` 将被提取至表格中, `Button` 作为表格的标题。 -如果使用默认导出,文件名将作为表格标题。生成的内容如下: +上面是一个标准写法,其中 `ButtonProps` 将被提取至表格中, `Button` 作为表格的标题。如果使用默认导出,文件名将作为表格标题。 + +需要注意的是,export 导出事先定义的特性将不会被解析。 + +```tsx +const A = () => {}; + +export { A }; // wrong +export default A; // wrong +export const B = () => {}; // right +export default () => {}; // right +``` + +生成的内容如下: ```mdx ### ButtonTest @@ -262,6 +274,12 @@ export const Button = (props?: ButtonProps) => {}; } ``` +更好的方式是直接引用类型,例如 + +```tsx +import { FC } from 'react'; +``` + ::: - `documentation`适用于工具库场景,用来解析 JSDoc 注释。