In this section, we will learn about creating ad-hoc pages in Docusaurus using React. This is most useful for creating one-off standalone pages like a showcase page, playground page or support page.
The functionality of pages is powered by
Adding a new page
/src/pages/ directory, create a file called
hello.js with the following contents:
Once you save the file, the development server will automatically reload the changes. Now open http://localhost:3000/hello, you will see the new page you just created.
Each page doesn't come with any styling. You will need to import the
Layout component from
@theme/Layout and wrap your contents within that component if you want the navbar and/or footer to appear.
You can also create a page in TypeScript, in which case the file name should use the
.tsx extension, eg.
/src/pages/ directory will be automatically converted to a website page, following the
/src/pages/ directory hierarchy. For example:
In this component-based development era, it is encouraged to co-locate your styling, markup and behavior together into components. Each page is a component, and if you need to customize your page design with your own styles, we recommend co-locating your styles with the page component in its own directory. For example, to create a "Support" page, you could do one of the following:
- Add a
- Create a
/src/pages/support/directory and a
The latter is preferred as it has the benefits of letting you put files related to the page within that directory. For example, a CSS module file (
styles.module.css) with styles meant to only be used on the "Support" page. Note: this is merely a recommended directory structure and you will still need to manually import the CSS module file within your component module (
src/pages/ directory will have corresponding website paths generated for them. Do not put reusable components or test files (ending with
.test.js) into that directory otherwise they will be turned into pages, which might not be intended.
React is used as the UI library to create pages. Every page component should export a React component and you can leverage on the expressiveness of React to build rich and interactive content.