--- title: 'DocsPage' ---
💡 NOTE: Currently there's an issue when using MDX stories with IE11. This issue does not apply to DocsPage. If you're interested in helping us fix this issue, read our Contribution guidelines and submit a pull request.
When you install [Storybook Docs](https://storybook.js.org/addons/@storybook/addon-docs), DocsPage is the zero-config default documentation that all stories get out of the box. It aggregates your [stories](../get-started/whats-a-story.md), text descriptions, docgen comments, [args tables](./doc-blocks.md#argstable), and code examples into a single page for each component. The best practice for docs is for each component to have its own set of documentation and stories. ## Component parameter Storybook uses the `component` key in the story file’s default export to extract the component's description and props. ## Subcomponents parameter Sometimes it's helpful to document multiple components together. For example, a component library’s ButtonGroup and Button components might not make sense without one another. DocsPage has the concept of a "primary" component defined by the `component` parameter. It also accepts one or more `subcomponents`. ![Subcomponents in Docs Page](./docspage-subcomponents.png) Subcomponent `ArgsTables` will show up in a tabbed interface along with the primary component. The tab titles will correspond to the keys of the subcomponents object. If you want to organize your documentation differently for component groups, we recommend using MDX. It gives you complete control over how it's displayed and supports any configuration. ## Replacing DocsPage Replace the DocsPage template with your own to customize its contents. ### With null to remove docs Override the `docs.page` [parameter](../writing-stories/parameters.md) with `null` to remove its contents. ### With MDX documentation Write your documentation in MDX and update the `docs.page` [parameter](../writing-stories/parameters.md) to display it. The `id` of reference follows the pattern: `group-subgroup-...--name`, where the `groups` and `subgroups` are defined as according to the [Grouping Documentation](https://storybook.js.org/docs/react/writing-stories/naming-components-and-hierarchy#grouping). ### With a custom component Storybook's UI is built using React. If you want to include a custom component to display documentation, you'll need to update your environment to allow React components to be correctly transpiled. For example, with Angular start by adding a `babel.config.js` file at the root of the project with the following content: ```js // babel.config.js module.exports = function(api) { process.env.NODE_ENV === 'development' ? api.cache(false) : api.cache(true); const presets = [ [ '@babel/preset-env', { targets: { node: 'current', }, }, ], '@babel/preset-typescript', '@babel/preset-react', ]; const plugins = []; return { presets, plugins, }; }; ``` Then, update your `tsconfig.json` to include the following: ```json { "compilerOptions": { .... "allowJs": true, "jsx": "react-jsx", }, } ``` Finally write your custom React component and and update the `docs.page` [parameter](../writing-stories/parameters.md) to render the custom documentation. ## Remixing DocsPage using doc blocks Doc blocks are the basic building blocks of Storybook Docs. DocsPage composes them to provide a reasonable UI documentation experience out of the box. If you want to make minor customizations to the default DocsPage but don’t want to write your MDX, you can remix DocsPage. That allows you to reorder, add, or omit doc blocks without losing Storybook’s automatic docgen capabilities. Here's an example of rebuilding DocsPage for the Button component using doc blocks: In addition, you can interleave your own components to customize the auto-generated contents of the page or pass in different options to the blocks to customize their appearance. Read more about [Doc Blocks](./doc-blocks.md). ## Story file names Unless you use a custom [webpack configuration](../configure/webpack.md#extending-storybooks-webpack-config), all of your story files should have the suffix `*.stories.@(j|t)sx?`. For example, "Badge.stories.js" or "Badge.stories.tsx". This tells Storybook and its docs preset to display the docs based on the file contents. ## Inline stories vs. iframe stories DocsPage displays all the stories of a component on one page. You have the option of rendering those stories inline or in an iframe. By default, we render React and Vue stories inline. Stories from other supported frameworks will render in an `