position |
---|
2 |
You can create pages under .theme/pages/
.
Content page is a page that uses <ContentDoc />
which renders given markdown
content as html. It is at .theme/pages/[...content-page].vue
which has a
catch all route to handle any markdown file in any directory.
We needed to load all markdown content under a folder in one page. To achieve
this we used queryContent
by which you can retrieve content under content/
folder.
Note
find
, findOne
methods return promise
so you need to wait with await
.
Demo is at /demo/query-content
Warning
We've disabled navigation
and surround
options to avoid extra queries
when a page is loaded. You might reenable these depending on the theme you
are using.
We needed to load all markdown content under a folder on a single page. When
there is no need to change the data we receive with queryContent
in the
script block, the query sent to the content with <ContentQuery>
was made to
reduce the crowd in the script.
Warning
Use <ContentQuery>
only if you know what you're doing, because it works in
the render stage. Otherwise, we strongly suggest usage of queryContent()
which runs once in setup stage.
Demo is at /demo/content-query
We don't use document-driven mode even if it's a website that contains only
markdown content. This is because all it does is to register a page with
catch-all route along with extra queries like navigation
, surround
which
could be unncessary in your theme. If you need to render navigation menu etc.,
use <ContentQuery>
or queryContent()
queries.
Warning
This project contains pages without a corresponding markdown content under
/demo
path. When you enable document-driven mode, dynamic pages under
/demo
will not work.
You can visit Routing to learn how to create custom pages for different types of routes.
We used layout to seperate header and sidebar components from pages. For nuxt
to recognize layouts, they should be implemented in .theme/layout
folder. To
create a layout create a default.vue
in the layout folder. Our implementation
is at .theme/layout/default.vue
. For layout to be used in every page it needs
to be added to app.vue
as shown in .theme/app.vue
.
To serve static assets in a theme like .css
or .png
files simply put any
file under .theme/public
folder. It will be served at the root path. E.g.
.theme/public/logo.png
will be at /logo.png
.
Demo is at /demo/public-assets.
Note
.png
from content images or generated diagrams should be served under
.theme/public
but they shouldn't be included in git. To preserve the
default behaviour while solving this problem, we change public assets folder
from .theme/public
to .theme/.public
via dir.public
in
.theme/nuxt.config.ts
and copy public assets, content images and generated
diagrams into .public
during preprocessing.
When we use Nuxt Content components <ContentDoc>
and <ContentQuery>
, we
configure the error content with #not-found
when the component cannot find
the markdown file it is looking for. To keep with the concept of managing the
content of each page with markdown, we get the #not-found
content from the
not-found.md
file.
Note
If you are getting the not-found content from markdown you should add a link
to generate.routes
. See
Configuration / Generate Routes for details.
Demo is at /demo/error/non-existent-content