vuepress侧边栏配置_超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法...

五一之前就想写一篇关于Vuepress的文章,结果朋友结婚就不了了之了。

记得最后一定要看注意事项!

Vuepress介绍

类似hexo一个极简的静态网站生成器,用来写技术文档不能在爽。当然搭建成博客也不成问题。

Vuepress特点

响应式,也可以自定义主题与hexo类似

内置markdown(还增加了一些扩展),并且可以在其使用Vue组件

Google Analytics 集成

PWA 自动生成Service Worker

快速上手

安装

初始化项目

yarn init -y

# 或者 npm init -y

安装vuepress

yarn add -D vuepress

# 或者 npm install -D vuepress

全局安装vuepress

yarn global add vuepress

# 或者 npm install -g vuepress

新建一个docs文件夹

mkdir docs

设置下package.json

{

"scripts": {

"docs:dev": "vuepress dev docs",

"docs:build": "vuepress build docs"

}

}

写作

yarn docs:dev # 或者:npm run docs:dev

也就是运行开发环境,直接去docs文件下书写文章就可以,打开http://localhost:8080/可以预览

构建

build生成静态的HTML文件,默认会在 .vuepress/dist 文件夹下

yarn docs:build # 或者:npm run docs:build

基本配置

在 .vuepress 目录下新建一个 config.js ,他导出一个对象

一些配置可以参考官方文档,这里我配置常用及必须配置的

网站信息

module.exports = {

title: '游魂的文档',

description: 'Document library',

head: [

['link', { rel: 'icon', href: `/favicon.ico` }],

],

}

导航栏配置

module.exports = {

themeConfig: {

nav: [

{ text: '主页', link: '/' },

{ text: '前端规范', link: '/frontEnd/' },

{ text: '开发环境', link: '/development/' },

{ text: '学习文档', link: '/notes/' },

{ text: '游魂博客', link: 'https://www.iyouhun.com' },

// 下拉列表的配置

{

text: 'Languages',

items: [

{ text: 'Chinese', link: '/language/chinese' },

{ text: 'English', link: '/language/English' }

]

}

]

}

}

如图:

侧边栏配置

可以省略 .md 扩展名,同时以 / 结尾的路径将会被视为 */README.md

module.exports = {

themeConfig: {

sidebar: {

'/frontEnd/': genSidebarConfig('前端开发规范'),

}

}

}

上面封装的 genSidebarConfig 函数

function genSidebarConfig(title) {

return [{

title,

collapsable: false,

children: [

'',

'html-standard',

'css-standard',

'js-standard',

'git-standard'

]

}]

}

支持侧边栏分组(可以用来做博客文章分类) collapsable是当前分组是否展开

module.exports = {

themeConfig: {

sidebar: {

'/note': [

{

title:'前端',

collapsable: true,

children:[

'/notes/frontEnd/VueJS组件编码规范',

'/notes/frontEnd/vue-cli脚手架快速搭建项目',

'/notes/frontEnd/深入理解vue中的slot与slot-scope',

'/notes/frontEnd/webpack入门',

'/notes/frontEnd/PWA介绍及快速上手搭建一个PWA应用',

]

},

{

title:'后端',

collapsable: true,

children:[

'notes/backEnd/nginx入门',

'notes/backEnd/CentOS如何挂载磁盘',

]

},

]

}

}

}

如图:

默认主题修改

主题色修改

在 .vuepress 目录下的创建一个 override.styl 文件

$accentColor = #3eaf7c // 主题色

$textColor = #2c3e50 // 文字颜色

$borderColor = #eaecef // 边框颜色

$codeBgColor = #282c34 // 代码背景颜色

自定义页面类

有时需要在不同的页面应用不同的css,可以先在该页面中声明

---

pageClass: custom-page-class

---

然后在 override.styl 中书写

.theme-container.custom-page-class {

/* 特定页面的 CSS */

}

PWA设置

设置serviceWorker为true,然后提供Manifest 和 icons,可以参考我之前的《PWA介绍及快速上手搭建一个PWA应用》

module.exports = {

head: [

['link', { rel: 'icon', href: `/favicon.ico` }],

//增加manifest.json

['link', { rel: 'manifest', href: '/manifest.json' }],

],

serviceWorker: true,

}

部署上线

设置基础路径

在 config.js 设置base 例如:你想要部署在https://foo.github.io 那么设置base为 / ,base默认就为 / ,所以可以不用设置 想要部署在https://foo.github.io/bar/,那么 base 应该被设置成 "/bar/"

module.exports = {

base: '/documents/',

}

base 将会自动地作为前缀插入到所有以 / 开始的其他选项的链接中,所以你只需要指定一次。

构建与自动部署

用 gitHub 的pages或者coding的pages都可以,也可以搭建在自己的服务器上。 将 dist 文件夹中的内容提交到git上或者上传到服务器就好

yarn docs:build # 或者:npm run docs:build

另外可以弄一个脚本,设置持续集成,在每次 push 代码时自动运行脚本

deploy.sh

#!/usr/bin/env sh

# 确保脚本抛出遇到的错误

set -e

# 生成静态文件

npm run docs:build

# 进入生成的文件夹

cd docs/.vuepress/dist

# 如果是发布到自定义域名

# echo 'www.example.com' > CNAME

git init

git add -A

git commit -m 'deploy'

# 如果发布到 https://.github.io

# git push -f git@github.com:/.github.io.git master

# 如果发布到 https://.github.io/

git push -f git@github.com:/.git master:gh-pages

cd -

注意事项(坑)

把你想引用的资源都放在 .vuepress 目录下的 public 文件夹

给git仓库绑定了独立域名后,记得修改base 路径

设置侧边栏分组后默认会自动生成 上/下一篇链接

设置了自动生成侧边栏会把侧边栏分组覆盖掉

设置PWA记得开启SSL

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值