--- title: 编写文章 icon: mingcute:edit-4-line createTime: 2024/03/04 10:06:06 permalink: /guide/write/ tags: - 指南 - 快速开始 --- VuePress 支持完整的 [Markdown 语法](../markdown/basic.md), 以及使用 [YAML](https://dev.to/paulasantamaria/introduction-to-yaml-125f) 定义 frontmatter 页面元数据,例如 标题和创建时间。 主题还对 Markdown 语法进行了 [扩展](../markdown/extensions.md) 支持。你还可以直接在 Markdown 中写 HTML ,或者使用 Vue 组件。 ## Frontmatter 你可以通过设置 frontmatter 中的值来自定义 VuePress 里每个页面。 Frontmatter 是你的文件顶部在 `---` 中间的部分。 ```md title="post.md" --- title: 文章标题 createTime: 2024/09/08 22:53:34 permalink: /article/9eh4d6ao/ --- 页面内容在第二个 `---` 后面。 ``` ::: details 什么是 frontmatter? frontmatter 是一个 [YAML](https://dev.to/paulasantamaria/introduction-to-yaml-125f) 格式的配置内容,被放置于 markdown 文件的顶部,通过 `---` 来分隔。 您可以阅读 [这篇文章](../../../../4.教程/frontmatter.md) 了解如何正确书写 frontmatter。 ::: ## 自动生成 Frontmatter 默认配置下,主题在启动开发服务后,会帮助为源目录中的 markdown 文件,生成一些 `frontmatter` 配置。 这些配置包括: __标题__, __创建时间__ 以及 __永久链接__。 一方面,这可以减少 内容创作者 的一些重复工作;另一方面,这些配置也为主题后续的其他功能提供了前置支持。 ```md --- title: 标题 createTime: 2024/09/08 22:53:34 permalink: /article/9eh4d6ao/ --- ``` ### 标题 主题默认 使用文件名作为文章标题。在解析 文件名 时,[文件命名约定](#文件夹命名约定) 所命名的文件名如 `1.我的文章.md`,其中 `1.` 和 `.md` 部分将被裁剪,最终文章标题为 `我的文章` 。 ### 创建时间 主题默认使用文件创建时间作为文章创建时间,并将其格式化为 `yyyy/MM/dd HH:mm:ss`。 ### 永久链接 __永久链接__ 指的是,文章发布后的 访问地址,这个地址一旦生成,只要您不手动修改它,即使文件路径、文件名发生改变也不会改变。 提前准备好 __永久链接__ 是比较有价值的,一方面,它可以帮助改善 站点的 SEO,避免收录的地址频繁变动; 另一方面,主题使用一套规范 生成 __永久链接__ ,它使得整个站点的 链接 风格一致。 - __博客文章__ 对于 博客文章,默认使用 `/article/` 作为永久链接的前缀,然后使用 [`nanoid`](https://github.com/ai/nanoid) 生成长度为 `8` 的随机字符串进行拼接,作为文章的永久链接, 如 `/article/9eh4d6ao/`。 对于链接前缀,还可以通过修改 [主题配置 > article](../../config/theme.md#article) 替换默认的 `/article/`。 - __notes__ 对于 notes , 主题使用更为灵活的自定义方案,你可以在 [notes > note.link](../../config/notes.md#配置) 声明不同的 note 的链接前缀,然后同样适用 [`nanoid`](https://github.com/ai/nanoid) 生成长度为 `8` 的随机字符串进行拼接,作为 note 文章的永久链接。 ### 禁用自动生成 你可能不想主题做额外的自动生成,希望由自己完全掌控。这完全没问题,主题支持通过配置来控制 自动生成 frontmatter 的行为。 通过 [主题配置 > autoFrontmatter](../../config/theme.md#autofrontmatter) 即可轻松做到。 ```ts title=".vuepress/config.ts" import { defineUserConfig } from 'vuepress' import { plumeTheme } from 'vuepress-theme-plume' export default defineUserConfig({ theme: plumeTheme({ // 完全禁用所有自动生成 // autoFrontmatter: false, // 控制部分自动生成 autoFrontmatter: { permalink: true, // 是否生成永久链接 createTime: true, // 是否生成创建时间 title: true, // 是否生成标题 } }) }) ``` ## 约定 ::: info 提示 以下内容,以 [项目结构](./project-structure.md) 中的文件结构作为基准。 ::: 使用本主题编写文章是一件很轻松的事情,你可以在 `docs`目录中按照你的个人命名喜好新建任意名字的`Markdown`文件。 ### 文件夹命名约定 对于 `docs` 中的文件夹命名,主题有一套简单的约定。 - 文件夹的名称将作为 `category` 即 __分类__。 - 允许多级目录,子级目录将作为父目录对应的分类的子项。 - 如果目录名称 在 [主题配置 notes](../../config/notes.md) 中声明用于 notes 文章管理,则默认不作为 分类目录。 由于文件夹名称将作为分类名称,且不在主题配置中进行排序配置,对于有排序需要的场景,使用以下规则进行命名: ``` ts :no-line-numbers const dir = /\d+\.[\s\S]+/ // 即 数字 + . + 分类名称 // 如: 1.前端 ``` 数字将作为 __排序__ 的依据。 如果不带数字,则以默认的规则进行排序。 __example:__ ::: file-tree - docs - 1.前端 - 1.html/ - 2.css/ - 3.javascript/ - 2.后端/ - 运维/ ::: 主题将根据 目录结构,生成一个 分类页。 ### 文件命名约定 - __博客文章__ 对于 __博客文章__ 的名称,主题没有任何约定,你可以任意命名。博客文章默认排序规则仅根据文件创建时间进行排序。 你还可以通过 [frontmatter > sticky](../../config/frontmatter/post.md#sticky) 配置文章是否置顶。 - __notes__ 对于 __notes__ 中的 markdown 文件名称,依然遵循 与 [文件夹命名约定](#文件夹命名约定) 相同的规则。 这可以为 notes 的 [自动生成侧边栏](../../config/notes.md#自动生成侧边栏) 提供排序依据。 ## 文章写作 你可以使用 `markdown` 语法开始在 `docs` 下新建 `Markdown` 文件,编写你自己的文章了, 关于 markdown 扩展的功能支持,请查看 [这个文档](../markdown/extensions.md) 由于主题默认会为文章 的 `frontmatter` 自动生成一个 `title`,因此,文章内容的主体部分的标题,起始应该从 `h2` 即 `## 二级标题` 开始。如果您禁用了 `autoFrontmatter.title`,那么应该使用 `h1` 即 `# 一级标题` 开始。 ### 标签 通过 `frontmatter.tags` 可以为文章添加标签。 ```md --- title: 我的文章 tags: - 标签 1 - 标签 2 --- ```