国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

超詳細動手搭建一個VuePress 站點及開啟PWA與自動部署的方法

2019-11-19 12:13:19
字體:
供稿:網(wǎng)友

五一之前就想寫一篇關(guān)于Vuepress的文章,結(jié)果朋友結(jié)婚就不了了之了。

記得最后一定要看注意事項!

Vuepress介紹

官網(wǎng):https://vuepress.vuejs.org/

類似hexo一個極簡的靜態(tài)網(wǎng)站生成器,用來寫技術(shù)文檔不能在爽。當(dāng)然搭建成博客也不成問題。

Vuepress特點

  • 響應(yīng)式,也可以自定義主題與hexo類似
  • 內(nèi)置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

設(shè)置下package.json

{ "scripts": {  "docs:dev": "vuepress dev docs",  "docs:build": "vuepress build docs" }}

寫作

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

也就是運行開發(fā)環(huán)境,直接去docs文件下書寫文章就可以,打開http://localhost:8080/可以預(yù)覽

 

構(gòu)建

build生成靜態(tài)的HTML文件,默認會在 .vuepress/dist 文件夾下

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

基本配置

.vuepress 目錄下新建一個 config.js ,他導(dǎo)出一個對象

一些配置可以參考官方文檔,這里我配置常用及必須配置的

網(wǎng)站信息

module.exports = { title: '游魂的文檔', description: 'Document library', head: [  ['link', { rel: 'icon', href: `/favicon.ico` }], ],}

導(dǎo)航欄配置

module.exports = { themeConfig: {  nav: [   { text: '主頁', link: '/' },   { text: '前端規(guī)范', link: '/frontEnd/' },   { text: '開發(fā)環(huán)境', link: '/development/' },   { text: '學(xué)習(xí)文檔', link: '/notes/' },   { text: '游魂博客', link: 'https://www.iyouhun.com' },   // 下拉列表的配置   {    text: 'Languages',    items: [     { text: 'Chinese', link: '/language/chinese' },     { text: 'English', link: '/language/English' }    ]   }  ] }}

如圖:

 

側(cè)邊欄配置

可以省略 .md 擴展名,同時以 / 結(jié)尾的路徑將會被視為 */README.md

module.exports = { themeConfig: {  sidebar: {   '/frontEnd/': genSidebarConfig('前端開發(fā)規(guī)范'),  } }}

上面封裝的 genSidebarConfig 函數(shù)

function genSidebarConfig(title) { return [{  title,  collapsable: false,  children: [   '',   'html-standard',   'css-standard',   'js-standard',   'git-standard'  ] }]}

支持側(cè)邊欄分組(可以用來做博客文章分類) collapsable是當(dāng)前分組是否展開

module.exports = { themeConfig: {  sidebar: {   '/note': [    {     title:'前端',     collapsable: true,     children:[      '/notes/frontEnd/VueJS組件編碼規(guī)范',      '/notes/frontEnd/vue-cli腳手架快速搭建項目',      '/notes/frontEnd/深入理解vue中的slot與slot-scope',      '/notes/frontEnd/webpack入門',      '/notes/frontEnd/PWA介紹及快速上手搭建一個PWA應(yīng)用',     ]    },    {     title:'后端',     collapsable: true,     children:[      'notes/backEnd/nginx入門',      'notes/backEnd/CentOS如何掛載磁盤',     ]    },   ]  } }}

如圖:

 

默認主題修改

主題色修改

.vuepress 目錄下的創(chuàng)建一個 override.styl 文件

$accentColor = #3eaf7c // 主題色$textColor = #2c3e50 // 文字顏色$borderColor = #eaecef // 邊框顏色$codeBgColor = #282c34 // 代碼背景顏色

自定義頁面類

有時需要在不同的頁面應(yīng)用不同的css,可以先在該頁面中聲明

---pageClass: custom-page-class---

然后在 override.styl 中書寫

.theme-container.custom-page-class { /* 特定頁面的 CSS */}

PWA設(shè)置

設(shè)置serviceWorker為true,然后提供Manifest 和 icons,可以參考我之前的《PWA介紹及快速上手搭建一個PWA應(yīng)用

module.exports = { head: [  ['link', { rel: 'icon', href: `/favicon.ico` }],  //增加manifest.json  ['link', { rel: 'manifest', href: '/manifest.json' }], ], serviceWorker: true,}

部署上線

設(shè)置基礎(chǔ)路徑

config.js 設(shè)置base 例如:你想要部署在https://foo.github.io 那么設(shè)置base為 / ,base默認就為 / ,所以可以不用設(shè)置 想要部署在https://foo.github.io/bar/,那么 base 應(yīng)該被設(shè)置成 "/bar/"

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

base 將會自動地作為前綴插入到所有以 / 開始的其他選項的鏈接中,所以你只需要指定一次。

構(gòu)建與自動部署

用 gitHub 的pages或者coding的pages都可以,也可以搭建在自己的服務(wù)器上。 將 dist 文件夾中的內(nèi)容提交到git上或者上傳到服務(wù)器就好

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

另外可以弄一個腳本,設(shè)置持續(xù)集成,在每次 push 代碼時自動運行腳本

deploy.sh

#!/usr/bin/env sh# 確保腳本拋出遇到的錯誤set -e# 生成靜態(tài)文件npm run docs:build# 進入生成的文件夾cd docs/.vuepress/dist# 如果是發(fā)布到自定義域名# echo 'www.example.com' > CNAMEgit initgit add -Agit commit -m 'deploy'# 如果發(fā)布到 https://<USERNAME>.github.io# git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git master# 如果發(fā)布到 https://<USERNAME>.github.io/<REPO>git push -f git@github.com:<USERNAME>/<REPO>.git master:gh-pagescd -

注意事項(坑)

  • 把你想引用的資源都放在 .vuepress 目錄下的 public 文件夾
  • 給git倉庫綁定了獨立域名后,記得修改base 路徑
  • 設(shè)置側(cè)邊欄分組后默認會自動生成 上/下一篇鏈接
  • 設(shè)置了自動生成側(cè)邊欄會把側(cè)邊欄分組覆蓋掉
  • 設(shè)置PWA記得開啟SSL

 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 安平县| 壶关县| 怀柔区| 福建省| 全椒县| 义马市| 普兰店市| 新巴尔虎右旗| 固阳县| 霍邱县| 凯里市| 金川县| 陆良县| 礼泉县| 连南| 清镇市| 武隆县| 潜江市| 通州市| 墨江| 五指山市| 沅陵县| 阿巴嘎旗| 宁南县| 晋州市| 安溪县| 和顺县| 南宁市| 普安县| 恩施市| 肇东市| 永福县| 依兰县| 常德市| 正宁县| 四会市| 宝清县| 连平县| 潮州市| 东莞市| 红安县|