替换主题组件
大约 5 分钟
当在 行为选项 中设置 { custom: true }
时,主题将通过 @theme-hope
别名来引入组件,所以你可以利用这一点来替换主题的任何一个组件。
如何通过别名替换组件
你需要在自己的 VuePress 配置文件通过 alias
替换主题中使用的组件别名。
import { getDirname, path } from "vuepress/utils";
import { hopeTheme } from "vuepress-theme-hope";
const __dirname = getDirname(import.meta.url);
export default {
theme: hopeTheme(
{
// 主题选项
// ...
},
{ custom: true },
),
alias: {
// 你可以在这里将别名定向到自己的组件
// 比如这里我们将主题的主页组件改为用户 .vuepress/components 下的 HomePage.vue
"@theme-hope/components/HomePage": path.resolve(
__dirname,
"./components/HomePage.vue",
),
},
};
可以支持的别名如下。
主题组件别名
组件:
@theme-hope/components/AutoLink
基础链接@theme-hope/components/BreadCrumb
路径导航@theme-hope/components/CommonWrapper
基本布局整合@theme-hope/components/FeaturePanel
主页特性@theme-hope/components/HeroInfo
主页 Logo 及介绍@theme-hope/components/HighlightPanel
: 主页亮点@theme-hope/components/HomePage
主页@theme-hope/components/MarkdownContent
Markdown 内容@theme-hope/components/NormalPage
常规页面@theme-hope/components/PageFooter
页脚@theme-hope/components/PageNav
页面导航@theme-hope/components/PageTitle
页面标题@theme-hope/components/PortfolioHero
档案主页@theme-hope/components/SkipLink
跳转到主内容
杂项:
@theme-hope/components/transitions/index
: 主题动画@theme-hope/components/icons/index
主题图标@theme-hope/composables/index
主题可组合 API@theme-hope/utils/index
主题通用函数
导航栏组件别名
组件:
@theme-hope/modules/navbar/components/NavbarDropdown
下拉列表@theme-hope/modules/navbar/components/LanguageDropdown
语言下拉列表@theme-hope/modules/navbar/components/NavActions
导航栏功能@theme-hope/modules/navbar/components/Navbar
导航栏@theme-hope/modules/navbar/components/NavbarBr和
导航栏品牌信息@theme-hope/modules/navbar/components/NavbarLinks
导航栏链接@theme-hope/modules/navbar/components/NavScreen
移动视图下的导航屏@theme-hope/modules/navbar/components/NavScreenMenu
移动视图下导航栏下拉菜单@theme-hope/modules/navbar/components/NavScreenLinks
移动式视图下导航栏链接@theme-hope/modules/navbar/components/RepoLink
仓库链接@theme-hope/modules/navbar/components/ToggleNavbarButton
导航栏切换按钮@theme-hope/modules/navbar/components/ToggleSidebarButton
侧边栏切换按钮
杂项:
@theme-hope/modules/navbar/components/icons/index
导航栏图标@theme-hope/modules/navbar/composables/index
导航栏可组合 API
侧边栏组件别名
组件:
@theme-hope/modules/sidebar/components/Sidebar
侧边栏@theme-hope/modules/sidebar/components/SidebarChild
侧边栏链接子项@theme-hope/modules/sidebar/components/SidebarGroup
侧边栏分组链接@theme-hope/modules/sidebar/components/SidebarLinks
侧边栏链接
杂项:
@theme-hope/modules/sidebar/composables/index
侧边栏可组合 API@theme-hope/modules/sidebar/utils/index
侧边栏通用函数
信息组件别名
组件:
@theme-hope/modules/info/components/AuthorInfo
作者信息@theme-hope/modules/info/components/CategoryInfo
分类信息@theme-hope/modules/info/components/DateInfo
写作日期信息@theme-hope/modules/info/components/OriginalInfo
原创标识@theme-hope/modules/info/components/PageInfo
页面信息@theme-hope/modules/info/components/PageMeta
页面元数据 information@theme-hope/modules/info/components/PageViewInfo
浏览量信息 information@theme-hope/modules/info/components/ReadingTimeInfo
阅读时间信息 time information@theme-hope/modules/info/components/TagInfo
标签信息@theme-hope/modules/info/components/TOC
内容列表@theme-hope/modules/info/components/WordInfo
字数信息
杂项:
@theme-hope/modules/blog/components/icons
信息图标@theme-hope/modules/blog/composables/index
信息可组合 API@theme-hope/modules/blog/utils/index
信息通用函数
博客组件别名
组件:
@theme-hope/modules/blog/components/ArticleItem
文章项@theme-hope/modules/blog/components/ArticleList
文章列表@theme-hope/modules/blog/components/ArticleType
文章类型@theme-hope/modules/blog/components/BloggerInfo
博主信息@theme-hope/modules/blog/components/BlogHero
博客主页 Logo 与介绍@theme-hope/modules/blog/components/BlogHome
博客主页@theme-hope/modules/blog/components/BlogWrapper
博客常规布局@theme-hope/modules/blog/components/CategoryList
分类列表@theme-hope/modules/blog/components/InfoList
博客信息列表@theme-hope/modules/blog/components/InfoPanel
博客信息面板@theme-hope/modules/blog/components/Pagination
分页组件@theme-hope/modules/blog/components/ProjectPanel
博客主页项目面板@theme-hope/modules/blog/components/SocialMedias
社交媒体链接@theme-hope/modules/blog/components/TagList
标签列表@theme-hope/modules/blog/components/TimelineItems
时间线项目@theme-hope/modules/blog/components/TimelineList
时间线列表
杂项:
@theme-hope/modules/blog/components/icons/index
博客图标@theme-hope/modules/blog/composables/index
博客可组合 API
加密组件别名
组件:
@theme-hope/modules/encrypt/components/GlobalEncrypt
全局加密@theme-hope/modules/encrypt/components/LocalEncrypt
本地加密@theme-hope/modules/encrypt/components/PasswordModal
密码输入框
杂项:
@theme-hope/modules/encrypt/composables/index
加密可组合 API@theme-hope/modules/encrypt/utils/index
加密通用函数
外观模块组件别名
组件:
@theme-hope/modules/outlook/components/ColorMode
主题颜色模式@theme-hope/modules/outlook/components/ColorModeSwitch
主题颜色开关@theme-hope/modules/outlook/components/OutlookButton
外观按钮@theme-hope/modules/outlook/components/OutlookSettings
外观设置@theme-hope/modules/outlook/components/ThemeColor
主题色@theme-hope/modules/outlook/components/ThemeColorPicker
主题色选择器@theme-hope/modules/outlook/components/ToggleFullScreen
全屏切换@theme-hope/modules/outlook/components/ToggleFullScreenButton
全屏切换按钮
杂项:
@theme-hope/modules/outlook/components/icons/index
外观图标@theme-hope/modules/outlook/composables/index
外观可组合 API
插槽利用
有些组件提供了插槽,在这种情况下,你可以在覆盖组件时直接引入原组件,并通过插槽传入你需要的内容。
提示
常用插槽位置示例,详见 主布局插槽演示。
比如你的网站社交属性很强,你希望在主页也显示评论框的话,你可以这样引入:
config.ts
import { getDirname, path } from "vuepress/utils";
import { hopeTheme } from "vuepress-theme-hope";
const __dirname = getDirname(import.meta.url);
export default {
theme: hopeTheme(
{
// 主题选项
// ...
},
{ custom: true },
),
alias: {
// 你可以在这里将别名定向到自己的组件
// 比如这里我们将主题的主页组件改为用户 .vuepress/components 下的 HomePage.vue
"@theme-hope/components/HomePage": path.resolve(
__dirname,
"./components/HomePage.vue",
),
},
};
HomePage.vue
<template>
<HopeHomePage>
<!-- 使用 bottom 插槽引入评论组件 -->
<template #bottom>
<CommentService />
</template>
</HopeHomePage>
</template>
<script setup lang="ts">
import HopeHomePage from "vuepress-theme-hope/components/HomePage.js";
</script>
提供插槽的组件如下:
主题:
AutoLink
:default
,before
,after
CommonWrapper
:default
,navScreenTop
,navScreenBottom
,sidebar
,sidebarTop
,sidebarBottom
HeroInfo
:logo
,info
,bg
logo
插槽将接收image
imageDark
style
alt
和isFullScreen
属性。info
插槽将接收text
tagline
和isFullScreen
属性。bg
插槽将接收image
bgStyle
和isFullScreen
属性。
HomePage
:top
,center
,bottom
NormalPage
:top
,contentBefore
,contentAfter
,bottom
,tocBefore
,tocAfter
博客:
ArticleItem
:title
,cover
,info
,excerpt
title
插槽将接收title
isEncrypted
和type
属性。excerpt
插槽将接收excerpt
属性。cover
插槽将接收cover
属性。info
插槽将接收info
属性。
BlogHero
:bg
,info
info
插槽将接收text
tagline
image
imageDark
style
alt
和isFullScreen
属性。bg
插槽将接收image
bgStyle
和isFullScreen
属性。
PortfolioHero
:avatar
bg
,info
avatar
插槽将接收avatar
avatarDark
avatarStyle
和alt
属性。info
插槽将接收name
welcome
title
titles
和links
属性。bg
插槽将接收image
imageDark
和bgStyle
属性。
导航栏:
NavbarDropdown
:title
NavActions
:before
,after
Navbar
:startBefore
,startAfter
,centerBefore
,centerAfter
,endBefore
,endAfter
NavbarBrand
:default
NavScreen
:before
,after
NavScreenMenu
:before
,after
侧边栏:
Sidebar
:top
,default
,bottom
TOC:
TOC
:before
,after
提示
对于每个插槽的对应位置和功能,请详见 主题源码。