In this section, we'll cover the basics to start building an application.
src/
โโโ components/
โ โโโ ReadingTime.vue
โ โโโ Author.vue
โ
โโโ layouts/
โ โโโ default.vue
โ โโโ post.vue
โ
โโโ pages/
โ โโโ posts/
โ โ โโโ intro.mdx
โ โ โโโ goodbye.mdx
โ โโโ about.vue
โ โโโ index.mdx
โ
โโโ app.ts
โโโ site.ts
By default, srcDir is aliased as ~/
or @/
. For example:
import { useDark } from '~/logic/dark'
<img src="@/assets/logo.svg"/>
Components in the src/components dir will be auto-imported on-demand, powered by unplugin-vue-components
.
extends this so that you don't need to import components in MDX files.
Routes will be auto-generated for files in the src/pages dir with the same file structure.
Pages can be Vue components or MDX files, and may specify frontmatter and route metadata.
You may use Vue components inside MDX, and access any properties defined in the frontmatter:
---
title: Song for You
audio: /song-for-you.mp3
---
I've recently recorded a song, listen:
<Song title={title} src={audio}/>
In Vue single-file components you can use a <page>
block to define frontmatter:
<page>
title: Song for You
audio: /song-for-you.mp3
</page>
<template>
<p>I've recently recorded a song, listen:</p>
<Song :title="$frontmatter.title" :src="$frontmatter.audio"/>
</template>
Page Hooks ๐ฃYou can customize all pages using the extendFrontmatter and extendRoute hooks.
You may access information about the current page using the usePage
composition API helper, or by using the $frontmatter
or $meta
global properties.
frontmatter
: The frontmatter of an MDX document or Vue component (in <page>
)meta
: Information about the page, including href
, filename
, and lastUpdated
<script setup>
import { usePage } from 'iles'
const { frontmatter, meta } = usePage()
</script>
Composables are auto-importedYou don't need to import usePage, useRoute, useHead, or definePageComponent.
You can leverage import.meta.glob
to import page components, which is
very convenient when rendering collections or index pages.
export function getPosts () {
const posts = Object.values(
import.meta.globEagerDefault('../pages/posts/**/*.mdx')
)
return posts.sort(byDate)
}
Page data is available directly in the component modules:
<script setup lang="ts">
import { getPosts } from '~/logic/posts'
const posts = getPosts()
</script>
<template>
<h1>Posts</h1>
<article v-for="post of posts" :key="post.href">
<time :datetime="post.date.toISOString()">{{ formatDate(post.date) }}</time>
<h2>
<a :href="post.href">{{ post.title }}</a>
</h2>
<component :is="post"/>
</article>
</template>
Components in the src/layouts dir will be available as layouts, and they should provide a default <slot/>
.
Pages may specify a layout using the layout
property in frontmatter:
---
layout: post
---
Layouts and Vue pages can also specify a parent layout using a layout
attribute in the template
:
<template layout="post">
The
default
layout will be used for all pages unless specified.Pages may opt-out by specifying
layout: false
Layout files must be lowercase, as in
post.vue
ordefault.vue
.
src/site.ts
can be used to provide site-wide information such as title
, description
, etc.
It can be accessed as $site
in component instances, or by using usePage
.
It's also displayed in the page information in Islands devtools.
export default {
title: 'About',
description: 'Learn more about what we do',
}
A sitemap can be automatically generated for your site, all you need to do is
configure siteUrl. That will also make it available as site.url
and site.canonical
.
import { defineConfig } from 'iles'
export default defineConfig({
siteUrl: 'https://iles-docs.netlify.app',
})
If you would like to opt-out, you can disable it explicitly:
export default defineConfig({
ssg: {
sitemap: false
},
})
Page information is available in a debug panel, similar to Vitepress, but you may also access an Islands inspector in Vue devtools.
This can be useful when debugging islands hydration.