2022-07-07 18:27:34 +00:00
---
title: 'content'
2022-11-21 15:51:39 +00:00
head.title: 'content/'
2023-10-18 10:59:43 +00:00
description: Use the content/ directory to create a file-based CMS for your application.
2024-09-17 15:33:49 +00:00
navigation.icon: i-ph-folder
2022-07-07 18:27:34 +00:00
---
2023-10-18 10:59:43 +00:00
[Nuxt Content ](https://content.nuxt.com ) reads the [`content/` directory ](/docs/guide/directory-structure/content ) in your project and parses `.md` , `.yml` , `.csv` and `.json` files to create a file-based CMS for your application.
2022-07-07 18:27:34 +00:00
- Render your content with built-in components.
- Query your content with a MongoDB-like API.
- Use your Vue components in Markdown files with the MDC syntax.
- Automatically generate your navigation.
2023-10-18 10:59:43 +00:00
::read-more{to="https://content.nuxt.com" target="_blank"}
Learn more in **Nuxt Content** documentation.
2022-07-07 18:27:34 +00:00
::
2023-10-18 10:59:43 +00:00
## Enable Nuxt Content
2022-07-07 18:27:34 +00:00
2023-10-18 10:59:43 +00:00
Install the `@nuxt/content` module in your project as well as adding it to your `nuxt.config.ts` with one command:
2022-07-07 18:27:34 +00:00
2023-10-18 10:59:43 +00:00
```bash [Terminal]
npx nuxi module add content
2022-07-07 18:27:34 +00:00
```
2023-10-18 10:59:43 +00:00
## Create Content
2022-07-07 18:27:34 +00:00
2023-10-18 10:59:43 +00:00
Place your markdown files inside the `content/` directory:
2022-07-07 18:27:34 +00:00
```md [content/index.md]
# Hello Content
```
The module automatically loads and parses them.
2023-10-18 10:59:43 +00:00
## Render Content
2022-07-07 18:27:34 +00:00
2025-01-20 13:50:01 +00:00
To render content pages, add a [catch-all route ](/docs/guide/directory-structure/pages/#catch-all-route ) using the [`<ContentRenderer>` ](https://content.nuxt.com/docs/components/content-renderer ) component:
2022-07-07 18:27:34 +00:00
2023-08-03 11:05:29 +00:00
```vue [pages/[...slug\\].vue]
2025-01-20 13:50:01 +00:00
< script lang = "ts" setup >
const route = useRoute()
const { data: page } = await useAsyncData(route.path, () => {
return queryCollection('content').path(route.path).first()
})
< / script >
2022-07-07 18:27:34 +00:00
< template >
2025-01-20 13:50:01 +00:00
< div >
< header > <!-- ... --> < / header >
< ContentRenderer v-if = "page" :value = "page" / >
< footer > <!-- ... --> < / footer >
< / div >
2022-07-07 18:27:34 +00:00
< / template >
```
## Documentation
2024-02-21 17:09:45 +00:00
::tip{ icon="i-ph-book" }
2023-10-18 10:59:43 +00:00
Head over to < https: / / content . nuxt . com > to learn more about the Content module features, such as how to build queries and use Vue components in your Markdown files with the MDC syntax.
2022-07-07 18:27:34 +00:00
::