VuePress 使用详解

一、核心概念

VuePress 是 Vue.js 团队开发的静态网站生成器,专为技术文档优化,具备以下特性:

  • Markdown 优先:原生支持 Markdown 语法扩展
  • Vue 驱动:可在 Markdown 中使用 Vue 组件
  • 默认主题优化:内置响应式布局、搜索功能、自动生成侧边栏
  • SEO 友好:自动生成服务端渲染(SSR)的静态内容

二、快速上手流程

1. 环境准备

  • Node.js:要求 ≥ v18.0(推荐 LTS 版本)
  • 包管理器:npm(v9.0+)或 yarn
# 验证安装
node -v
npm -v

2. 项目初始化

mkdir vuepress-demo && cd vuepress-demo
npm init -y

3. 安装 VuePress

npm install -D vuepress@next

4. 项目结构

.
├── docs
│   ├── .vuepress
│   │   └── config.js  # 配置文件
│   ├── README.md      # 首页
│   └── guide
│       └── advanced.md # 其他页面
└── package.json

三、核心配置详解

1. 基础配置 (docs/.vuepress/config.js)

import { defineUserConfig } from 'vuepress'
import { defaultTheme } from '@vuepress/theme-default'export default defineUserConfig({lang: 'zh-CN',title: '我的知识库',description: 'VuePress 使用指南',theme: defaultTheme({logo: '/images/logo.png',navbar: [{ text: '首页', link: '/' },{ text: '指南', link: '/guide/' }],sidebar: {'/guide/': [{ text: '快速入门', link: '/guide/' },{ text: '进阶配置', link: '/guide/advanced' }]}})
})

2. 首页配置 (docs/README.md)

---
home: true
heroText: VuePress 知识库
tagline: 让文档管理更简单
actions:- text: 快速上手 →link: /guide/
features:- title: 简洁至上details: 基于 Markdown 的极简写作体验- title: Vue 驱动details: 在 Markdown 中使用 Vue 组件- title: 高性能details: 预渲染静态 HTML + SPA 加载
---

四、核心功能实践

1. Markdown 扩展语法

# 代码块高亮
```js
console.log('Hello VuePress!')

自定义容器

::: tip
这是提示信息
:::


### 2. 自动生成侧边栏
在 `config.js` 中配置:
```javascript
sidebar: 'auto' // 根据文档结构自动生成

3. 搜索功能配置

themeConfig: {search: true,searchMaxSuggestions: 10
}

五、高级功能

1. 自定义主题

  1. 创建主题文件夹:
mkdir docs/.vuepress/theme
  1. 创建布局组件 (docs/.vuepress/theme/Layout.vue):
<template><div><NavBar /><SideBar /><Content /><Footer /></div>
</template>
  1. config.js 中启用:
theme: require.resolve('./theme')

2. 插件系统

安装官方插件示例

npm install @vuepress/plugin-google-analytics@next

配置使用

plugins: [['@vuepress/google-analytics', {id: 'G-XXXXXXX'}]
]

推荐插件

  • 代码复制vuepress-plugin-nuggets-style-copy
  • 动态标题vuepress-plugin-dynamic-title
  • 看板娘@vuepress-reco/vuepress-plugin-kan-ban-niang

六、部署指南

1. GitHub Pages 部署

  1. config.js 中设置基础路径:
base: '/repository-name/',
  1. 创建 .github/workflows/deploy.yml
name: Deploy
on:push:branches:- main
jobs:deploy:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v2- run: npm install- run: npm run docs:build- name: Deploy to GitHub Pagesuses: peaceiris/actions-gh-pages@v3with:github_token: ${{ secrets.GITHUB_TOKEN }}publish_dir: ./docs/.vuepress/dist

2. 本地构建命令

# 本地开发
npx vuepress dev docs# 生产构建
npx vuepress build docs

七、常见问题解决

Q1: 图片资源加载失败
将图片放在 docs/.vuepress/public/ 目录,使用绝对路径引用:

![img](/image.png)

Q2: 样式覆盖技巧
创建 docs/.vuepress/styles/palette.scss

$accentColor: #ff6464;

Q3: 代码块高亮配置
config.js 中添加:

markdown: {extendMarkdown: md => {md.use(require('markdown-it-prism'))}
}

八、学习资源推荐

  1. VuePress 官方文档
  2. Vue.js 中文文档
  3. Markdown 官方教程

通过本文档,您已经掌握了 VuePress 的完整使用流程。立即开始您的技术文档创作之旅吧!


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/91514.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/91514.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI大模型前沿:Muyan-TTS开源零样本语音合成技术解析

AI大模型前沿&#xff1a;Muyan-TTS开源零样本语音合成技术解析引言&#xff1a;语音合成技术的演进与Muyan-TTS的突破性意义语音合成&#xff08;Text-to-Speech, TTS&#xff09;技术作为人机交互的核心接口之一&#xff0c;自20世纪30年代贝尔实验室首次尝试电子语音合成以来…

c# everthing.exe 通信

1 获取everthing进程 调用 Everything 搜索创建SearchWithEverything函数using Microsoft.Win32; using System; using System.Diagnostics; using System.IO; using System.Management; using System.Text;class EverythingHelper {// 方法 1&#xff1a;从进程获取路径publi…

Gitee:中国企业级DevOps平台的本土化突围之路

Gitee&#xff1a;中国企业级DevOps平台的本土化突围之路 在国内数字化转型浪潮下&#xff0c;DevOps平台作为企业研发效能提升的核心引擎&#xff0c;正在经历从工具到生态的全面升级。作为国内领先的一站式DevOps解决方案&#xff0c;Gitee凭借其本土化优势与全链路服务能力&…

C++法则22:运算符 ::* 和 ->* 和 ::* 是独特的整体运算符,是不可分的。

C法则22&#xff1a;运算符 ::* 和 ->* 和 ::* 是独特的整体运算符&#xff0c;是不可分的。1. ::*&#xff08;成员指针声明符&#xff09;作用&#xff1a;用于声明一个指向类成员的指针。语法&#xff1a;ReturnType (ClassName::*pointerName) &ClassName::MemberN…

Linux系统管理习题

Linux 系统管理练习题 1.请为此虚拟机配置以下网络参数&#xff1a; 1&#xff09;主机名&#xff1a;chenyu.example.com &#xff08;将chenyu改成自己名字的全拼&#xff09; 2&#xff09;IP 地址&#xff1a;192.168.100.100/24 3&#xff09;默认网关&#xff1a;192.168…

SQL166 每天的日活数及新用户占比

SQL166 每天的日活数及新用户占比 题目理解 本SQL查询旨在分析用户活跃数据&#xff0c;计算两个关键指标&#xff1a; 每日活跃用户数(DAU)每日新增用户占比(新用户占活跃用户的比例) 解题思路 1. 数据准备阶段 首先我们需要获取所有用户的活跃记录&#xff0c;包括&…

【33】C# WinForm入门到精通 ——表格布局器TableLayoutPanel【属性、方法、事件、实例、源码】

WinForm 是 Windows Form 的简称&#xff0c;是基于 .NET Framework 平台的客户端&#xff08;PC软件&#xff09;开发技术&#xff0c;是 C# 语言中的一个重要应用。 .NET 提供了大量 Windows 风格的控件和事件&#xff0c;可以直接拿来使用。 本专栏内容是按照标题序号逐渐…

uv使用教程

以下是使用 Python 包管理工具 uv 的常见命令指南。uv 是由 Astral&#xff08;Ruff 的开发者&#xff09;开发的高性能 Python 包安装器和解析器&#xff0c;旨在替代 pip 和 pip-tools&#xff1a; 1. 安装 uv uv官网仓库 # Linux/macOS curl -Ls https://astral.sh/uv/in…

SpringBoot3.x入门到精通系列:1.1 简介与新特性

SpringBoot 3.x 简介与新特性 &#x1f4d6; 什么是SpringBoot SpringBoot是由Pivotal团队提供的全新框架&#xff0c;其设计目的是用来简化Spring应用的初始搭建以及开发过程。SpringBoot集成了大量常用的第三方库配置&#xff0c;SpringBoot应用中这些第三方库几乎可以零配…

二、搭建springCloudAlibaba2021.1版本分布式微服务-Nacos搭建及服务注册和配置中心

nacos介绍 1、Nacos简介 Nacos 是阿里巴巴推出来的一个新开源项目&#xff0c;这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集&#xff0c;帮助您快速实现动态服务发现、…

浅谈物联网嵌入式程序开发源码技术方案

在物联网蓬勃发展的时代&#xff0c;嵌入式程序作为连接硬件与软件的桥梁&#xff0c;发挥着至关重要的作用。以“边缘智能 云协同”为核心&#xff0c;为工业、医疗、家居、农业、智慧城市五大场景提供稳定、低功耗、可扩展的物联网终端与平台一体化解决方案。以下董技叔软件…

【笔记】重学单片机(51)

为学习嵌入式做准备&#xff0c;重新拿起51单片机学习。此贴为学习笔记&#xff0c;仅记录易忘点&#xff0c;实用理论基础&#xff0c;并不是0基础。 资料参考&#xff1a;清翔零基础教你学51单片机 51单片机学习笔记1. C语言中的易忘点1.1 数据类型1.2 位运算符1.3 常用控制语…

C++现代Redis客户端库redis-plus-plus详解

&#x1f680; C现代Redis客户端库redis-plus-plus详解&#xff1a;告别繁琐的hiredis&#xff0c;拥抱现代C的Redis操作 &#x1f4c5; 更新时间&#xff1a;2025年07月28日 &#x1f3f7;️ 标签&#xff1a;C | Redis | redis-plus-plus | 现代C | 后端开发 文章目录&#x…

Redis存储原理与数据模型(上)

一、Redis数据模型 1.1、查看Redis数据定义&#xff1a; typedef struct redisDb {kvstore *keys; /* The keyspace for this DB 指向键值存储的指针&#xff0c;用于快速访问和修改数据库中的键值对*/kvstore *expires; /* Timeout of keys with a t…

视频生成模型蒸馏的方法

1.fastvideo https://github.com/hao-ai-lab/FastVideohttps://github.com/hao-ai-lab/FastVideo Distillation support Recipes for video DiT, based on PCM. Support distilling/finetuning/inferencing state-of-the-art open video DiTs: 1. Mochi 2. Hunyuan. 2.l

【mysql】—— mysql中的timestamp 和 datetime(6) 有什么区别,为什么有的地方不建议使用timestamp

在 MySQL 中,TIMESTAMP 和 DATETIME(6) 都是用于存储日期和时间的数据类型,但它们在存储范围、时区处理、存储方式等方面有显著区别。 1. 核心区别对比 特性 TIMESTAMP DATETIME(6) 存储范围 1970-01-01 00:00:01 UTC ~ 2038-01-19 03:14:07 UTC(受限于 32 位时间戳) 1000…

前端下载文件相关

1、下载 ‘Content-Type‘: ‘application/octet-stream‘ 的文件 当后端返回的响应头中 Content-Type 为 application/octet-stream 时&#xff0c;表示这是一个二进制流文件&#xff0c;浏览器无法直接展示&#xff0c;需要前端处理后下载到本地。 通过请求获取二进制数据…

代码随想录算法训练营第五十六天|动态规划part6

108.冗余连接 题目链接&#xff1a;108. 冗余的边 文章讲解&#xff1a;代码随想录 思路&#xff1a; 题意隐含 只有一个冗余边 #include <iostream> #include <vector> using namespace std; int n1001; vector<int>father(n,0);void init(){for(int i0;…

智能体通信协议

智能体通信协议A2AACPANPAgoraagents.jsonLMOSAITPA2A A2A官方文档&#xff1a;https://www.a2aprotocol.net/docs/introduction 开源代码和详细规范&#xff1a;https://github.com/google/A2A ACP ACP官方文档&#xff1a;https://acp.agentunion.cn ANP ANP官方文档&am…

QT交叉编译环境配置

QT交叉编译环境配置1 配置交叉编译工具链1.1 解压 放到/opt中1.2 使用环境变量1.2.1 设置成永久的环境变量1.2.2 临时环境变量1.3 安装编译需要的软件2 编译tslib库&#xff08;如果不需要触摸屏直接跳过&#xff09;3. 编译qt3.1 编译源码3.2 设置QCreator4 说明4.1 关于编译器…