Skip to content

xuzhongpeng/vuepress-theme-reform

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

介绍

项目地址:vuepress-theme-reform

效果展示: 我的博客

立即下载zip包体验(项目已简单配置好): blog.zip

此主题继承至 vuepress 的默认主题,添加功能有标签页改造,主页改造,博客分类及展示,gitalk 集成及 gitalk 自动化配置

使用

npm install vuepress-theme-reform -D # or yarn add vuepress-theme-reform

然后在 docs/.vuepress/config.js 文件中添加

{
  ...
  theme:'reform'
  ...
}

即可使用本主题

功能介绍

主页展示

如需使用主页展示 在 docs 下的 README.md 中修改 defaultHome:true

---
defaultHome: true
___

主页展示

目录分类及展示

在 config.js 中配置

...
nav: [
      ...
      {
        text: "博文",
        icon: 'zhi',
        items: [
          { text: "前端", link: "/blog/frontend/" }
        ]
      }
      ...
]

在 docs/blog/frontend 下新建 README.md,在头部编写

---
type: 'classify'
---

那此文件夹下的其它文件都会被编译成展示的博文,此中的/blog/frontend 自行定义 分类

标签云集成

在 docs 下新建 tags,在 tags 下新建空的 README.md

在 config.js 中的 themeConfig 下配置

...
themeConfig:{
  ...
  tags:"tags"
  ...
  nav:[
    ...
    {
        text: "标签云",
        link: '/tags/',
        tags: true
      },
      ...
  ]
}
...

其中后面的 tags 表示你标签云的文件夹名

在我们写的文章中写

---
tags:
  - vuepress
---

就能在页面中看到效果 标签云

gitalk

在 config.js 中配置

{
  themConfig:{
    ...
    gitalk: {
      // gitalk的主要参数
      clientID: `your clientID`,
      clientSecret: `your clientSecret`,
      repo: `your repo`,
      owner: "yourname",
      admin: ["yourname"],
      accessToken: 'your accessToken ',
      labelRule: `(title,path)=> {
        let paths=path.split('/')
        if(paths.length>0){
          let res = paths.pop()
          if(res===''){
            res=paths.pop()
          }
          res = res.slice(-50)
          return res
        }else{
          return title
        }
      }`
    },
    ...
  }
}
  • clientID: 你的 clientID,在 github 的 Settings/Developer settings/OAuth Apps 下创建获取
  • clientSecret: 你的 clientSecret,在 github 的 Settings/Developer settings/OAuth Apps 下创建获取
  • repo: 你的评论存放的仓库名,如我的为 xuzhongpeng.github.io
  • owner: 你的 github 账户名
  • admin: 评论下展示的名字
  • accessToken: 可选,用于自动化创建 gitalk 时发送请求的 taken,在 github 的 Settings/Developer settings/Personal access tokens 下创建获取
  • labelRule: 评论请求及自动化创建评论时的回调函数,有回调函数的原因在于 gitalk 标签只能有 50 个字符的限制,回调函数的第一个参数为当前页面的标题,第二个参数当前页面的路径,返回创建的标签名

gitalk 自动化创建

下载安装插件

yarn add vuepress-plugin-gitalk # npm i vuepress-plugin-gitalk -D

在 package.json 中的 scripts 中加入

{
  "scripts":{
    ...
    "gitalk": "vuepress gitalk ./docs",
    ...
  }
}

执行

npm run gitalk

即可输出自动化初始化评论的结果

最新 Google Analytics 插件集成

vuepress 提供了@vuepress/plugin-google-analytics,我使用过后没有效果,去 google-analytics 网站上发现当前的插入代码已有变化,所以自己内置了插件,只需在 config.js 中配置即可。

{
  ga:'XXXX'
}

错误处理

如果自动化创建评论时输出

接口返回数据{"message":"Bad credentials","documentation_url":"https://developer.github.com/v3"}
xxx 创建失败

报这个错误大概率是 accessToken 失效了,这时需要重新到 github 的 Settings/Developer settings/Personal access tokens 下创建获取并替换

项目地址:vuepress-theme-reform

效果展示: 我的博客

补充功能

---
title: 我的博客   //标题
sidebar: false  //是否展示侧边栏
navbar: false   //是否展示菜单
gitTalk: false  //是否显示评论
sidebarDepth: 2 //侧边栏展示文章层级
tags:   //标签
  - javascript
---