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

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

Vuepress介绍

官网:https://vuepress.vuejs.org/

类似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' > CNAMEgit init
git add -A
git commit -m 'deploy'# 如果发布到 https://<USERNAME>.github.io
# git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git master# 如果发布到 https://<USERNAME>.github.io/<REPO>
git push -f git@github.com:<USERNAME>/<REPO>.git master:gh-pagescd -
复制代码

注意事项(坑)

  • 把你想引用的资源都放在.vuepress目录下的public文件夹
  • 给git仓库绑定了独立域名后,记得修改base路径
  • 设置侧边栏分组后默认会自动生成 上/下一篇链接
  • 设置了自动生成侧边栏会把侧边栏分组覆盖掉
  • 设置PWA记得开启SSL

超详细动手搭建一个 VuePress 站点及开启 PWA 与自动部署相关推荐

  1. 虚拟机屏幕显示不全(界面大小更改 )虚拟机Ubuntu18.04 的超详细环境搭建教程/步骤 SDN软件定义网络实验

    打开虚拟机后,我们可能发现,桌面周围有大量黑边,且有些界面无法完整显示,影响我们的感受和操作!!!  解决方法: (1)点击箭头所指,进入目录 (2)点击箭头所指的齿轮,进入"setting ...

  2. 运用PyTorch动手搭建一个共享单车预测器

    本文摘自 <深度学习原理与PyTorch实战> 我们将从预测某地的共享单车数量这个实际问题出发,带领读者走进神经网络的殿堂,运用PyTorch动手搭建一个共享单车预测器,在实战过程中掌握神 ...

  3. 搭建一个jupyter站点做数据分析吧

    jupyter jupyter 是一个非常适合做数据分析的工作台.为了可以使得jupyter可以运行在服务器上访问生产环境的数据,今天我要在服务器上搭建一个jupyter站点. 容器 为了不和线上的其 ...

  4. 自己动手搭建一个简单的静态资源服务器

    文章目录 自己动手搭建一个简单的静态资源服务器 介绍 一.设计到的模块 备注: 二.代码结构 三.具体代码 自己动手搭建一个简单的静态资源服务器 介绍 ​ 通过此文章的学习,可以自己使用NodeJs搭 ...

  5. 2023微信社区小程序+APP+后台,附带超详细完整搭建教程【源码+教程】

    2023微信社区小程序+APP+后台,附带超详细完整搭建教程[源码+教程] 微信授权登陆正常,小程序和APP带后台 手机号登陆正常,发帖,建圈子.发活动. 微信小程序是一种轻量级的应用程序,可以在微信 ...

  6. spring boot:从零开始搭建一个项目 - day 5 Mybatis plus代码自动生成器

    spring boot:从零开始搭建一个项目 - day 5 Mybatis plus代码自动生成器 一.Mybatis plus代码自动生成器 1.引入配置 2.创建Controller 3.执行m ...

  7. 自己动手搭建一个简单的网站

    我准备搭建一个属于自己的网站,一方面是了解建站的知识,另一个方面是为了测试Http请求相关的内容. 建站资料 下面是建站需要的资料: 服务器:也就是高级一点的电脑,它主要用来存放网页数据: web服务 ...

  8. 自己动手搭建一个OA办公系统,可行吗?

    企业管理,有统一的企业规范非常重要,但是企业的条条框框下,员工们工作效率和办公流程流转的速度却又无法保证了,许多"为别人背锅".浑水摸鱼的情况层出不穷,发展到最后,团队的整体意识和 ...

  9. 使用Go自己动手搭建一个HTTP代理服务器

    代理服务器的工作方式如下: 客户端向代理服务器发送请求,表明自己需要请求的网站内容 代理服务器接收到来自客户端的请求之后,通过解析,获取到需要访问的web服务 代理服务器将客户端的请求信息全部转发给w ...

最新文章

  1. Ten ways to improve the performance of large tables in MySQL--转载
  2. 【ArcGIS 10.2新特性】ArcGIS 10.2 for Server新特性
  3. 不能执行autowired_想用@Autowired注入static静态成员?官方不推荐你却还偏要这么做...
  4. ThingsBoard 小结
  5. JMetro“ Metro”选项卡,Java的TreeView和ContextMenu(JavaFX)
  6. 多媒体计算机技术19秋作业1,东师多媒体计算机技术19春在线作业1【标准答案】.doc...
  7. 在stackoverflow上使用markdown
  8. Struts12---文件的下载
  9. 用拉普拉斯变换求零状态响应_什么是UPS?为什么用UPS?关于UPS电源的知识都在这里!...
  10. [游戏开发]iOS 游戏开发教程资源
  11. 带你玩转 Visual Studio——带你跳出坑爹的 Runtime Library 坑
  12. 这个Excel函数,推荐所有人学习!HR都说必须会
  13. 苹果和谷歌应用商店的APP搜索排名算法
  14. 7-2 愿天下有情人都是失散多年的兄妹
  15. 利用MODIS TOOL批量重投影MODIS
  16. java实现三角螺旋阵
  17. bookkeeper metadata 获取及密码安全
  18. Freemarker源码分析(9)core.JSONParser类
  19. ANSYS workbench数值分析 新手教程(1)
  20. 安卓六大平台开发者注册地址和方法链接

热门文章

  1. JS-数组和函数冒泡排序递归函数
  2. 【Vue案例二】实现对表单数据的添加、删除以及关键字查询操作
  3. HTML5 —— 本地存储
  4. URI、URL和URN的关系
  5. 基于FPGA的红外遥控解码与PC串口通信
  6. Dom-to-image
  7. Cycle-2(循环)
  8. java applet鼠标点击事件_Swing 鼠标单击事件?
  9. 有头结点单链表的逆置
  10. idea安装sbt插件linux,【idea】kafkasbt+idea安装配置与测试