一.添加评论插件
使用giscus
来做vitepress
的评论模块,使用也非常的简单,具体可以参考:giscus 文档,首先安装giscus
npm i @giscus/vue
二.giscus操作
打开giscus 文档,如下图所示,填入你的 github 用户名 + 仓库名
,勾选你需要的配置
data:image/s3,"s3://crabby-images/56da5/56da53e1d1f2d6785cb87657eb255308023759d8" alt=""
如果显示不成功看是否满足上面三个条件:
1.公开仓库
2.在github安装giscuss app插件
data:image/s3,"s3://crabby-images/67813/6781374590c876141521487f864db7e2bd92d2ce" alt=""
3.打开discussion功能
找到setting
data:image/s3,"s3://crabby-images/e4df6/e4df63c50eabb33c2c164f36ca9df1b3188c9f24" alt=""
往下翻打开discussion
data:image/s3,"s3://crabby-images/fd31e/fd31efb2fee3fa8db7cb64be9486f9ad3d811ded" alt=""
这样之后就会满足条件,giscus找到下面位置内容,后面要用
data:image/s3,"s3://crabby-images/01ea4/01ea4eaf7852ee10add76cefb443bce47db6f73c" alt=""
三.vitePress配置
在.vitepress/theme/
目录下创建myLayout.vue
组件,添加 giscus 评论组件,
javascript
<!--Layout.vue-->
<template>
<Layout>
<template #doc-footer-before> </template>
<template #doc-after>
<div style="margin-top: 24px">
<Giscus
:key="page.filePath"
repo="*"
repo-id="*"
category="*"
category-id="*"
mapping="pathname"
strict="0"
reactions-enabled="1"
emit-metadata="0"
input-position="bottom"
lang="zh-CN"
crossorigin="anonymous"
:theme="isDark ? 'dark' : 'light'"
/>
</div>
</template>
</Layout>
</template>
<script lang="ts" setup>
import Giscus from "@giscus/vue";
import DefaultTheme from "vitepress/theme";
import { watch } from "vue";
import { inBrowser, useData } from "vitepress";
const { isDark, page } = useData();
const { Layout } = DefaultTheme;
watch(isDark, (dark) => {
if (!inBrowser) return;
const iframe = document
.querySelector("giscus-widget")
?.shadowRoot?.querySelector("iframe");
iframe?.contentWindow?.postMessage(
{ giscus: { setConfig: { theme: dark ? "dark" : "light" } } },
"https://giscus.app"
);
});
</script>
在.vitepress/index.js
配置文件中使用自定义布局。
javascript
import DefaultTheme from 'vitepress/theme'
import Layout from './myLayout.vue'
// import Layout from './Layout.vue'
export default {
Layout,
extends: DefaultTheme,
enhanceApp({ app }) {
//app.component('confetti', confetti)
},
}
四、效果
data:image/s3,"s3://crabby-images/800bb/800bba220e4d1c8b8d13dae5ccffacdee3e67a2c" alt=""