Markdown Features
Docusaurus supports Markdown and a few additional features.
Front Matter
Markdown documents have metadata at the top called Front Matter:
---
id: my-doc-id
title: My document title
description: My document description
slug: /my-custom-url
---
## Markdown heading
Markdown text with [links](./hello.md)
Links
Regular Markdown links are supported, using url paths or relative file paths.
Let's see how to [Create a page](/create-a-page).
Let's see how to [Create a page](./create-a-page.md).
Result: Let's see how to Create a page.
Images
Regular Markdown images are supported.
You can use absolute paths to reference images in the static directory (static/img/docusaurus.png
):
![Docusaurus logo](/img/docusaurus.png)
You can reference images relative to the current file as well. This is particularly useful to colocate images close to the Markdown files using them:
![Docusaurus logo](./img/docusaurus.png)
Code Blocks
Markdown code blocks are supported with Syntax highlighting.
```jsx title="src/components/HelloDocusaurus.js"
function HelloDocusaurus() {
return <h1>Hello, Docusaurus!</h1>
}
```
function HelloDocusaurus() {
return <h1>Hello, Docusaurus!</h1>
}
Admonitions
Docusaurus has a special syntax to create admonitions and callouts:
:::tip[My tip]
Use this awesome feature option
:::
:::danger[Take care]
This action is dangerous
:::
Use this awesome feature option
This action is dangerous
MDX and React Components
MDX can make your documentation more interactive and allows using any React components inside Markdown:
export const Highlight = ({children, color}) => (
<span
style={{
backgroundColor: color,
borderRadius: '20px',
color: '#fff',
padding: '10px',
cursor: 'pointer',
}}
onClick={() => {
alert(`You clicked the color ${color} with label ${children}`)
}}>
{children}
</span>
);
This is <Highlight color="#25c2a0">Docusaurus green</Highlight> !
This is <Highlight color="#1877F2">Facebook blue</Highlight> !
This is Docusaurus green !
This is Facebook blue !
- HTML
- CSS
- JavaScript
<div class="grid-container-many-element">
<div
class="grid-element"
style="
background-color: #df5457;
transform: rotate(-3deg) translateY(10px);
opacity: 1;
"
></div>
<div
class="grid-element"
style="
background-color: #48a6cc;
transform: rotate(2deg) translateY(-3px);
opacity: 1;
"
></div>
<div
class="grid-element"
style="
background-color: #f69551;
transform: rotate(-8deg) translateY(-1px);
opacity: 1;
"
></div>
<div
class="grid-element"
style="
background-color: #f8efe6;
transform: rotate(-16deg) translateY(2px);
opacity: 1;
"
></div>
</div>
.grid-container-many-element {
height: 300px;
display: grid;
/* place-content: center; */
/* 或 */
place-items: center;
/* 或者 */
/* 水平居中 */
/* justify-content: center; */
/* 垂直居中 */
/* justify-items: center; */
}
.grid-element {
min-width: 120px !important;
height: 120px !important;
grid-column: 1;
grid-row: 1;
}