超詳細動手搭建一個Vuepress站點及開啟PWA與自動部署,vuepresspwa

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

類似hexo一個極簡的靜態網站生成器,用來寫技術文檔不能在爽。愛掏網 - it200.com當然搭建成博客也不成問題。愛掏網 - it200.com

  • 響應式,也可以自定義主題與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 */
}

設置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 將會自動地作為前綴插入到所有以 / 開始的其他選項的鏈接中,所以你只需要指定一次。愛掏網 - it200.com

構建與自動部署

用gitHub的pages或者coding的pages都可以,也可以搭建在自己的服務器上。愛掏網 - it200.com
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
聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
發表評論
更多 網友評論0 條評論)
暫無評論

返回頂部

主站蜘蛛池模板: 亚洲熟女综合色一区二区三区| 国模无码一区二区三区| 国产亚洲精品精品国产亚洲综合| 亚洲中久无码永久在线观看同| 5g影院天天爽天天| 日韩欧美一区二区三区免费看| 欧美性大战久久久久xxx| 天天想你电视剧| 人人狠狠综合久久亚洲| 99爱在线精品免费观看| 波多野结衣不卡| 国产综合色在线视频区| 亚洲欧美日韩精品久久亚洲区| 69av在线视频| 欧美专区在线视频| 国产成a人亚洲精v品无码| 久久嫩草影院免费看夜色| 荡公乱妇hd在线| 成年女人免费v片| 冠希与阿娇实干13分钟视频| www.日韩av.com| 波多野结衣在线不卡| 国产精品美女久久久久av福利| 亚洲人成在线播放网站| 黑人巨大无码中文字幕无码| 日美女大长腿b| 四虎a456tncom| eeuss影院免费92242部| 欧美激情视频一区二区三区| 国产真实偷乱小说| 久久国产精品免费一区二区三区| 色橹橹欧美在线观看视频高清| 新婚夜的娇吟声| 伊人色综合九久久天天蜜桃| 7777奇米四色| 日韩人妻潮喷中文在线视频| 同学浓精灌麻麻| aaaaaa级特色特黄的毛片| 欧美另类69xxxx| 国产亚洲人成网站观看| 一级做a爰性色毛片|