当前位置: 首页 > news >正文

VitePress 自定义 CSS 指南

VitePress 是一款基于 Vite 和 Vue 3 的静态网站生成器,专为文档编写而设计。尽管 VitePress 提供了丰富的默认主题,但在某些情况下,我们可能需要对其进行更深入的定制以满足特定的视觉需求。本文将详细介绍如何通过覆盖根级别的 CSS 变量来自定义 VitePress 的默认主题 CSS。

覆盖根级别的 CSS 变量

VitePress 的默认主题使用 CSS 变量来定义颜色、字体、阴影等样式属性。通过覆盖这些变量,我们可以轻松地调整整个站点的视觉风格。

步骤 1: 创建自定义 CSS 文件

首先,在你的 VitePress 项目中,创建一个自定义 CSS 文件。例如,在 .vitepress/theme 目录下创建一个名为 custom.css 的文件。

mkdir -p .vitepress/theme
touch .vitepress/theme/custom.css

步骤 2: 覆盖 CSS 变量

custom.css 文件中,你可以覆盖任何你希望改变的 CSS 变量。以下是一些示例:

/* .vitepress/theme/custom.css */
:root {--vp-c-brand-1: #646cff; /* 更改品牌主色调 */--vp-c-brand-2: #747bff; /* 更改品牌次色调 */--vp-c-text-1: #333; /* 更改主文字颜色 */--vp-c-bg: #f4f4f4; /* 更改背景颜色 */
}

步骤 3: 引入自定义 CSS 文件

接下来,你需要在自定义主题入口文件中引入这个 CSS 文件。如果你的项目结构遵循 VitePress 的默认布局,这个文件通常是 .vitepress/theme/index.js

// .vitepress/theme/index.js
import DefaultTheme from 'vitepress/theme'
import './custom.css' // 引入自定义 CSSexport default DefaultTheme

步骤 4: 覆盖黑暗模式下的样式

如果你的站点支持黑暗模式,你还需要考虑在 .dark 类下覆盖相应的 CSS 变量。

/* .vitepress/theme/custom.css */
.dark {--vp-c-brand-1: #ff646c; /* 黑暗模式下的品牌主色调 */--vp-c-brand-2: #ff747b; /* 黑暗模式下的品牌次色调 */--vp-c-text-1: #eee; /* 黑暗模式下的主文字颜色 */--vp-c-bg: #333; /* 黑暗模式下的背景颜色 */
}

示例:完整 CSS 变量列表

VitePress 的默认主题使用了大量的 CSS 变量,涵盖了颜色、字体、阴影、布局等各个方面。以下是一个简化的 CSS 变量列表示例,展示了你可以覆盖的一些常见变量:

:root {--vp-c-brand-1: #646cff; /* 品牌主色调 */--vp-c-text-1: #333; /* 主文字颜色 */--vp-c-bg: #fff; /* 背景颜色 */--vp-font-family-base: 'Inter', sans-serif; /* 基础字体 */--vp-code-font-size: 0.875em; /* 代码字体大小 */--vp-code-block-bg: #f8f8f8; /* 代码块背景颜色 *//* 更多变量... */
}

结论

通过覆盖根级别的 CSS 变量,你可以轻松地自定义 VitePress 站点的视觉风格。这包括颜色、字体、阴影等多个方面,使你的文档网站更具个性和专业感。记得在自定义主题入口文件中引入你的 CSS 文件,并确保在黑暗模式下也进行适当的样式调整。希望这篇文章能帮助你更好地掌握 VitePress 的 CSS 定制技巧!

http://www.lryc.cn/news/431956.html

相关文章:

  • 【舍入,取整,取小数,取余数丨Excel 函数】
  • 无线信道中ph和ph^2的场景
  • HCIA--实验五:静态路由综合实验
  • 不同vlan之间的通信方法
  • java后端框架
  • 如何在Word中插入复选框
  • Android 源码中jni项目 加载so目录小结
  • 24/9/6算法笔记 kaggle 房屋价格
  • 【MA35D1】buildroot 编译使用经验
  • 排查 MyBatis XML 配置中的 IF 语句与传值名称不匹配的 Bug
  • 数字证书与公钥基础设施
  • 拥抱数智化,JNPF低代码平台如何推动企业转型升级
  • Linux shell脚本 (十二)case语句_linux awk case语句
  • 【二等奖成品论文】2024年数学建模国赛B题25页成品论文+完整matlab代码、python代码等(后续会更新)
  • 国内快速高效下载 HuggingFace上的各种大语言模型
  • linux proxy 【linux 代理】
  • AcWing907. 区间覆盖
  • Unity TMP (TextMeshPro) 更新中文字符集
  • Leetcode3259. 超级饮料的最大强化能量
  • Java题集(由入门到精通)03
  • zblog自动生成文章插件(百度AI写作配图,图文并茂)
  • 华为 HCIP-Datacom H12-821 题库 (4)
  • 使用seq_file
  • 期货赫兹量化-种群优化算法:进化策略,(μ,λ)-ES 和 (μ+λ)-ES
  • pytest实战演练
  • 7、关于LoFTR
  • 硬件工程师笔试面试知识器件篇——电感
  • 代码随想录八股训练营第三十六天| C++
  • 学习计算机网络
  • Django发送邮件