超详细动手搭建一个Vuepress站点及开启PWA与自动部署

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

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

Vuepress介绍

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

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

Vuepress特点

  • 响应式,也可以自定义主题与hexo类似
  • 内置markdown(还增加了一些扩展),并且可以在其使用Vue组件
  • Google Analytics 集成
  • PWA 自动生成Service Worker

快速上手

安装

初始化项目

  1. yarn init -y
  2. # 或者 npm init -y

安装vuepress

  1. yarn add -D vuepress
  2. # 或者 npm install -D vuepress

全局安装vuepress

  1. yarn global add vuepress
  2. # 或者 npm install -g vuepress

新建一个docs文件夹

  1. mkdir docs

设置下package.json

  1. {
  2. "scripts": {
  3. "docs:dev": "vuepress dev docs",
  4. "docs:build": "vuepress build docs"
  5. }
  6. }

写作

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

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

 
image

构建

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

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

基本配置

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

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

网站信息

  1. module.exports = {
  2. title: '游魂的文档',
  3. description: 'Document library',
  4. head: [
  5. ['link', { rel: 'icon', href: `/favicon.ico` }],
  6. ],
  7. }

导航栏配置

  1. module.exports = {
  2. themeConfig: {
  3. nav: [
  4. { text: '主页', link: '/' },
  5. { text: '前端规范', link: '/frontEnd/' },
  6. { text: '开发环境', link: '/development/' },
  7. { text: '学习文档', link: '/notes/' },
  8. { text: '游魂博客', link: 'https://www.iyouhun.com' },
  9. // 下拉列表的配置
  10. {
  11. text: 'Languages',
  12. items: [
  13. { text: 'Chinese', link: '/language/chinese' },
  14. { text: 'English', link: '/language/English' }
  15. ]
  16. }
  17. ]
  18. }
  19. }

如图:

 
image

侧边栏配置

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

  1. module.exports = {
  2. themeConfig: {
  3. sidebar: {
  4. '/frontEnd/': genSidebarConfig('前端开发规范'),
  5. }
  6. }
  7. }

上面封装的genSidebarConfig函数

  1. function genSidebarConfig(title) {
  2. return [{
  3. title,
  4. collapsable: false,
  5. children: [
  6. '',
  7. 'html-standard',
  8. 'css-standard',
  9. 'js-standard',
  10. 'git-standard'
  11. ]
  12. }]
  13. }

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

  1. module.exports = {
  2. themeConfig: {
  3. sidebar: {
  4. '/note': [
  5. {
  6. title:'前端',
  7. collapsable: true,
  8. children:[
  9. '/notes/frontEnd/VueJS组件编码规范',
  10. '/notes/frontEnd/vue-cli脚手架快速搭建项目',
  11. '/notes/frontEnd/深入理解vue中的slot与slot-scope',
  12. '/notes/frontEnd/webpack入门',
  13. '/notes/frontEnd/PWA介绍及快速上手搭建一个PWA应用',
  14. ]
  15. },
  16. {
  17. title:'后端',
  18. collapsable: true,
  19. children:[
  20. 'notes/backEnd/nginx入门',
  21. 'notes/backEnd/CentOS如何挂载磁盘',
  22. ]
  23. },
  24. ]
  25. }
  26. }
  27. }

如图:

 
成品图

默认主题修改

主题色修改

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

  1. $accentColor = #3eaf7c // 主题色
  2. $textColor = #2c3e50 // 文字颜色
  3. $borderColor = #eaecef // 边框颜色
  4. $codeBgColor = #282c34 // 代码背景颜色

自定义页面类

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

  1. ---
  2. pageClass: custom-page-class
  3. ---

然后在override.styl中书写

  1. .theme-container.custom-page-class {
  2. /* 特定页面的 CSS */
  3. }

PWA设置

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

  1. module.exports = {
  2. head: [
  3. ['link', { rel: 'icon', href: `/favicon.ico` }],
  4. //增加manifest.json
  5. ['link', { rel: 'manifest', href: '/manifest.json' }],
  6. ],
  7. serviceWorker: true,
  8. }

部署上线

设置基础路径

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

  1. module.exports = {
  2. base: '/documents/',
  3. }

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

构建与自动部署

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

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

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

deploy.sh

  1. #!/usr/bin/env sh
  2. # 确保脚本抛出遇到的错误
  3. set -e
  4. # 生成静态文件
  5. npm run docs:build
  6. # 进入生成的文件夹
  7. cd docs/.vuepress/dist
  8. # 如果是发布到自定义域名
  9. # echo 'www.example.com' > CNAME
  10. git init
  11. git add -A
  12. git commit -m 'deploy'
  13. # 如果发布到 https://<USERNAME>.github.io
  14. # git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git master
  15. # 如果发布到 https://<USERNAME>.github.io/<REPO>
  16. git push -f git@github.com:<USERNAME>/<REPO>.git master:gh-pages
  17. cd -

注意事项(坑)

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

超详细动手搭建一个Vuepress站点及开启PWA与自动部署的更多相关文章

  1. (转)超详细单机版搭建hadoop环境图文解析

                        超详细单机版搭建hadoop环境图文解析   安装过程: 一.安装Linux操作系统 二.在Ubuntu下创建hadoop用户组和用户 三.在Ubuntu下安装 ...

  2. 利用Wamp在本地搭建一个wordpress站点

    原文链接:利用Wamp在本地搭建一个wordpress站点 有时候我们会想搭建一个自己的站点,可是由于只是想自己访问,就不是很想为这个站点在买一个服务器和域名,那我们可能首先就想到把自己电脑当做服务器 ...

  3. 超详细从零记录Hadoop2.7.3完全分布式集群部署过程

    超详细从零记录Ubuntu16.04.1 3台服务器上Hadoop2.7.3完全分布式集群部署过程.包含,Ubuntu服务器创建.远程工具连接配置.Ubuntu服务器配置.Hadoop文件配置.Had ...

  4. 两周“学会”bootstrap搭建一个移动站点

    一直想着用bootstrap搭建网站,它的自适应.元素封装完善.现成的Glyphicons字体图标,省去很多的css.js.ui的工作,可以快速搭建一个客户需要的站点.ytkah自己有一些div+cs ...

  5. 自己动手搭建一个简易的SpringBoot环境

    什么是springboot? Spring Boot俗称微服务.Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特 ...

  6. Hexo快速搭建静态博客并实现远程VPS自动部署

    这篇文章将如何搭建hexo,以及如何通过git webhooks实现远程vps的自动部署 这篇文件适合的条件: 简单的用于个人博客.公司博客展示,hexo的定位是静态博客,要实现动态服务器的功能并不适 ...

  7. 超详细!搭建本地大数据研发环境(16G内存+CDH)

    工欲善其事必先利其器,在经过大量的理论学习以后,需要有一个本地的研发环境来进行练手.已经工作的可以不依赖于公司的环境,在家也可以随意的练习.而自学大数据的同学,也可以进行本地练习,大数据是一门偏实践的 ...

  8. Centos 7搭建Gitlab服务器超详细Centos 7搭建Gitlab服务器超详细(搭建成功)

    一. 安装并配置必要的依赖关系在CentOS系统上安装所需的依赖:ssh,防火墙,postfix(用于邮件通知) ,wget,以下这些命令也会打开系统防火墙中的HTTP和SSH端口访问. 注意:用户不 ...

  9. 超详细单机版搭建hadoop环境图文解析

    前言: 年前,在老大的号召下,我们纠集了一帮人搞起了hadoop,并为其取了个响亮的口号“云在手,跟我走”.大家几乎从零开始,中途不知遇到多少问题,但终 于在回家之前搭起了一个拥有12台服务器的集群, ...

随机推荐

  1. Promise-async-await处理函数

    /*function request() { // 此处的request返回的是一个Promise return new Promise((resolve, reject) => { ajax( ...

  2. 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。

    示例 1: 输入: [1,2,3,4,5,6,7] 和 k = 3 输出: [5,6,7,1,2,3,4] 解释: 向右旋转 1 步: [7,1,2,3,4,5,6] 向右旋转 2 步: [6,7,1 ...

  3. echarts入门

    一直好奇,今晚就学习了一番,算是入门的级别,学习总是一个渐进的过程. 一路记录,一路足迹. 一:学习资料 1.主要参考的代码 https://github.com/shengxinjing/imooc ...

  4. day67 ORM模型之高阶用法整理,聚合,分组查询以及F和Q用法,附练习题整理

    归纳总结的笔记: day67 ORM 特殊的语法 一个简单的语法 --翻译成--> SQL语句 语法: 1. 操作数据库表 创建表.删除表.修改表 2. 操作数据库行 增.删.改.查 怎么连数据 ...

  5. VS2017动态链接库(.dll)的生成与使用

    转 https://blog.csdn.net/m0_37170593/article/details/76445972 这里以VS2017为例子,讲解一下动态链接库(.dll)的生成与使用. 一.动 ...

  6. URAL 1989 Subpalindromes (多项式hash) +【线段树】

    <题目链接> <转载于 >>>  > 题目大意:给你一段字符串,进行两种操作:1.询问[l,r]这个区间中的字符串是否是回文串: 2.更改该字符串中对应下标的 ...

  7. 课堂练习&课下作业----用户场景分析

    典型用户1 ·小明---一名普通大学生生 名字 小明 性别.年龄 男,19岁 职业 大学生 收入 无 知识层次和能力 石家庄铁道大学学生,善于交际. 生活/工作情况 成绩优异,各方面技能突出 动机,目 ...

  8. [Python]Flask 源代码分析-config

    flask有一个Config类,含from_object, from_pyfile, from_environ等载入命名空间的方法.载入命名空间的本质是载入一个dict[key]=value的字典. ...

  9. Linux服务部署--Java(二)

    八.Maven安装配置 1. 下载 wget http://mirrors.cnnic.cn/apache/maven/maven-3/3.3.9/binaries/apache-maven-3.3. ...

  10. me 云面试

    元祖的特点: 1.元组内的元素,不可以增加,删除,只能访问,这个是元祖的特性,比较安全.类似于字符串.但是我们可以对整个元祖进行删除.使用del内置函数 2.当元祖内只有一个元素的时候,需要加逗号消除 ...