Add reading time
本頁內容尚未翻譯。
Create a remark plugin which adds a reading time property to the frontmatter of your Markdown or MDX files. Use this property to display the reading time for each page.
Recipe
Section titled Recipe- 
Install Helper Packages Install these two helper packages: - reading-timeto calculate minutes read
- mdast-util-to-stringto extract all text from your markdown
 Terminal window npm install reading-time mdast-util-to-stringTerminal window pnpm add reading-time mdast-util-to-stringTerminal window yarn add reading-time mdast-util-to-string
- 
Create a remark plugin. This plugin uses the mdast-util-to-stringpackage to get the Markdown file’s text. This text is then passed to thereading-timepackage to calculate the reading time in minutes.remark-reading-time.mjs import getReadingTime from 'reading-time';import { toString } from 'mdast-util-to-string';export function remarkReadingTime() {return function (tree, { data }) {const textOnPage = toString(tree);const readingTime = getReadingTime(textOnPage);// readingTime.text will give us minutes read as a friendly string,// i.e. "3 min read"data.astro.frontmatter.minutesRead = readingTime.text;};}
- 
Add the plugin to your config: astro.config.mjs import { defineConfig } from 'astro/config';import { remarkReadingTime } from './remark-reading-time.mjs';export default defineConfig({markdown: {remarkPlugins: [remarkReadingTime],},});Now all Markdown documents will have a calculated minutesReadproperty in their frontmatter.
- 
Display Reading Time If your blog posts are stored in a content collection, access the remarkPluginFrontmatterfrom theentry.render()function. Then, renderminutesReadin your template wherever you would like it to appear.src/pages/posts/[slug].astro ---import { CollectionEntry, getCollection } from 'astro:content';export async function getStaticPaths() {const blog = await getCollection('blog');return blog.map(entry => ({params: { slug: entry.slug },props: { entry },}));}const { entry } = Astro.props;const { Content, remarkPluginFrontmatter } = await entry.render();---<html><head>...</head><body>...<p>{remarkPluginFrontmatter.minutesRead}</p>...</body></html>If you’re using a Markdown layout, use the minutesReadfrontmatter property fromAstro.propsin your layout template.src/layouts/BlogLayout.astro ---const { minutesRead } = Astro.props.frontmatter;---<html><head>...</head><body><p>{minutesRead}</p><slot /></body></html>