Advanced
Raw Content
Access to contents raw data in appliction
There were lots of requests in Content version 2 about accessing contents raw data in production. In Content version 3 it is possible to ship contents raw data to production.
In order to ship raw contents to production you need to define rawbody
field in your collection's schema. That's it.
Nuxt Content will detect this magical field in your schema and fill it with the raw content.
content.config.ts
import { defineCollection, defineContentConfig, z } from '@nuxt/content'
export default defineContentConfig({
collections: {
docs: defineCollection({
source: '**',
type: 'page',
schema: z.object({
rawbody: z.string()
})
})
}
})
And you can use queryCollection()
to fetch the raw content.
pages/index.vue
<script setup lang="ts">
const route = useRoute()
const { data } = useAsyncData('page-' + route.path, () => queryCollection('docs').path(route.path).first())
</script>
<template>
<pre>{{ data.rawbody }}</pre>
</template>
In case you don't want to ship raw content of a specific file you can add rawbody: ''
to frontmatter of that file. The auto filled value of rawbody
is acting like default value and when you define rawbody
in the frontmatter it will overwritten.
content.md
---
title: My page
rawbody: ''
---
It is important to fill frontmatter fields with a same type of data that is defined in collection schema. In this case
rawbody
is a string, and you should consider passing empty string. Do not use boolean
or other type of values.