文档如何自动化部署到线上环境「每个前端都可以拥有自己的博客」

简介: 文档如何自动化部署到线上环境「每个前端都可以拥有自己的博客」

前言


说起文档,我们可能会第一时间会想起很多技术文档,比如Vue.js文档、React.js文档、TypeScript文档,它们都有相似的布局和样式。


那么,作为开发者的我们,怎么不也搞一个类似于技术文档的网站作为自己的博客呢?现在有很多开源的项目可以做博客,比如基于Vue.js开发的Vuepress以及同一家的Vitepress,还有基于React.js开发的Docusaurus。这么多方案,我们今天就拿Vuepress为例来搞一下线上可以访问的博客。


在开始实战之前呢!透露一下最近在搞得开源库Strve.js,它是一个可以将字符串转换为视图的JS库,换句话讲,也可以说是一款轻量的MVVM框架。目前Strve.js官方文档就是用的基于Vuepress来进行开发部署的,感兴趣的可以访问下方的官方文档源码地址,可以根据我的来进行自定义配置自己的博客网站。如果觉得不错的话,别忘了帮忙点个Star啊!


Strve.js官方文档源码地址

github.com/maomincodin…


Strve.js官方文档

maomincoding.github.io/strvejs-doc…


实战


自己亲身实战所攒下的经验,请认真往下看哦!


学习一个新技术,我们首先做得事就是打开官网文档,根据快速上手或者指南来进行大致的了解。


第一步


打开Vuepress官网:

vuepress.vuejs.org/zh/


官网上怎么安装Vuepress项目已经很详细了,这里就不再阐述,可以根据快速上手快速搭建一个Vuepress项目。


vuepress.vuejs.org/zh/guide/ge…


一般搭建完成之后,会显示以下目录结构:


.
├── docs
│   ├── .vuepress (可选的)
│   │   ├── components (可选的)
│   │   ├── theme (可选的)
│   │   │   └── Layout.vue
│   │   ├── public (可选的)
│   │   ├── styles (可选的)
│   │   │   ├── index.styl
│   │   │   └── palette.styl
│   │   ├── templates (可选的, 谨慎配置)
│   │   │   ├── dev.html
│   │   │   └── ssr.html
│   │   ├── config.js (可选的)
│   │   └── enhanceApp.js (可选的)
│   │ 
│   ├── README.md
│   ├── guide
│   │   └── README.md
│   └── config.md
└── package.json


第二步


假设你已经在第一步中成功搭建起了项目,并且成功启动。下面,我们将会改改代码看下都是什么效果。


首先,我会看下这个文件doc > README.md,这个文件你可以把它理解成首页。


.
├─ docs
│  ├─ README.md


以Strve.js文档首页为例:


---
home: true
heroImage: /logo.png
heroText: Strve.js
tagline: 一个可以将字符串转换为视图的JS库
actionText: 快速上手 →
actionLink: /zh/started/
features:
- title: ⚡️ 快速地
  details: 超快的虚拟 DOM。
- title: 📦 空间小
  details: 源代码文件大小仅仅4kb。
- title: 🗂 灵活地
  details: 易于灵活地拆装不同的代码块。
footer: MIT Licensed | Copyright © 2021-present maomincoding
---


上面的格式是Front Matter,可以根据官方文档进行详细配置。


vuepress.vuejs.org/zh/theme/de…


第三步


那么下面你需要关注的是Vuepress配置文件——config.js


.
├─ docs
│  └─ .vuepress
│     └─ config.js


同样,拿Strve.js官网文档为例:


module.exports = {
    base: '/strvejs-doc/', // /site/strvejs/
    title: 'Strve.js',
    description: 'A JS library that can convert strings into view',
    head: [
        ['link', { rel: 'icon', href: '/logo.png' }],
    ],
    markdown: {
        lineNumbers: true
    },
    locales: {
        '/': {
            lang: 'en-US',
            title: 'Strve.js',
            description: 'A JS library that can convert strings into view'
        },
        '/zh/': {
            lang: 'zh-CN',
            title: 'Strve.js',
            description: '一个可以将字符串转换为视图的JS库'
        }
    },
    themeConfig: {
        displayAllHeaders: true,
        sidebar: 'auto',
        sidebarDepth:4,
        nav: [
            { text: 'GitHub', link: 'https://github.com/maomincoding/strve' }
        ],
        locales: {
            '/': {
                selectText: 'Languages',
                label: 'English',
                ariaLabel: 'Languages',
                sidebar: [
                    {
                        title: 'Introduce',
                        path: '/introduce/',
                    },
                    {
                        title: 'Install',
                        path: '/install/',
                    },
                    {
                        title: 'Started',
                        path: '/started/',
                    },
                    {
                        title: 'Usage',
                        path: '/usage/',
                    },
                    {
                        title: 'Tool',
                        path: '/tool/',
                    },
                    {
                        title: 'Other',
                        path: '/other/',
                    }
                ],
            },
            '/zh/': {
                selectText: '选择语言',
                label: '简体中文',
                sidebar: [
                    {
                        title: '介绍',
                        path: '/zh/introduce/',
                    },
                    {
                        title: '安装',
                        path: '/zh/install/',
                    },
                    {
                        title: '快速上手',
                        path: '/zh/started/',
                    },
                    {
                        title: '使用',
                        path: '/zh/usage/',
                    },
                    {
                        title: '工具',
                        path: '/zh/tool/',
                    },
                    {
                        title: '其它',
                        path: '/zh/other/',
                    }
                ],
            }
        },
        smoothScroll: true
    }
}


看到这些配置不要慌,都可以从官方文档配置选项中可以找到。


vuepress.vuejs.org/zh/config/


其次,需要重点说明的是我这里//zh是提供了多语言支持配置路径,可以通过官方文档的多语言支持选项进行配置。


第四步


我之所以很简单地概括前面的步骤,是因为官网文档讲解的比我更明白更详细,我也不想浪费大家的时间。


下面,我们就要开始部署。在部署打包之前呢!我们首先要注意的是配置文件,我们回到之前的配置文件。


我们需要注意的是base选项,


module.exports = {
    base: '/strvejs-doc/', 
    title: 'Strve.js',
    description: 'A JS library that can convert strings into view',
    head: [
        ['link', { rel: 'icon', href: '/logo.png' }],
    ]
}


打开package.json文件。


{
  "name": "strvejsdoc",
  "version": "1.0.0",
  "description": "Strve.js document address",
  "main": "index.js",
  "license": "MIT",
  "private": false,
  "scripts": {
    "dev": "vuepress dev docs",
    "build": "vuepress build docs"
  },
  "devDependencies": {
    "vuepress": "^1.8.2"
  }
}


我们看到"scripts"属性下有"build"指令。运行打包即可。


打包后,默认会打包到dist文件夹中,你可以把文件夹中的内容放到线上网站上去,如果没有网站,也没有关系。本篇文章就是让每个前端都拥有一个属于自己的博客线上网站。


.
├── docs
│   ├── .vuepress
│   │   ├── dist


第五步


我们会用到GitHub,所以需要创建一个仓库,名字可以起一个好记的。我这里因为是以Strve.js为例,所以名为strvejs-doc。然后你需要做的是使用SSH方式Clone下来。


如果没有配置SSH的可以根据我下面的步骤操作一下。


  1. 切换到 .ssh目录


cd ~/.ssh


  1. 浏览文件夹目录


ls


  1. 输入你的邮箱(邮箱不必与GitHub账号相同,个人邮箱即可),然后一直回车


ssh-keygen -t rsa -C "邮箱"


  1. 自动启动


eval "$(ssh-agent -s)"


  1. 添加文件


ssh-add ~/.ssh/id_rsa


  1. 查看 id_rsa.pub 文件的内容,复制一下,留存。


cat id_rsa.pub


下面,我们就要打开Github,点击右上角个人头像下拉菜单中的Settings选项,然后点击左边栏的SSH and GPG keys选项。


点击 New SSH key 按钮。


输入Title 下的内容,这里随便起一个好记的标题。


然后输入Key 下的内容,把刚才保存的id_rsa.pub 文件的内容复制到里面。

现在,大功告成!


以后,你只需要复制项目仓库中 Clone按钮下的 SSH 选项框中的链接。

然后,Clone 这个链接即可。


Clone 下仓库之后,然后可以把刚才Vuepress项目导入进去。


最后,Push一下。


第六步


首先,我们需要创建一个分支,比如命名pages。然后,打开GitHub远程仓库,点击项目仓库Tab栏上的Settings选项,然后点击Pages选项。


最后,在Source下选择刚才创建的pages分支,然后选择/(root),点击Save保存按钮。


不出意外,上方会给出一个网址,这里我们先保存一下,待会配置完成我们再点击浏览网址。


第七步


在项目根目录下创建一个deploy.sh文件,编辑如下内容:


#!/usr/bin/env sh
set -e
npm run build
cd docs/.vuepress/dist
git init
git add -A
git commit -m 'deploy'
# 如果发布到 https://<USERNAME>.github.io/<REPO>
git push -f git@github.com:<USERNAME>/<REPO>.git master:pages
cd -


这里你需要自定义的是:USERNAMEREPOmaster:pages,分别对应用户名、仓库名、(一般是master:分支名或者main:分支名)。


第八步


我们在package.json文件中定义一个调试命令。


"scripts": {
    "sh":"bash deploy.sh"
}


然后运行此命令。


最后,我们在浏览器上打开刚才的网址。


maomincoding.github.io/strvejs-doc…


微信截图_20220506203506.png


以后,每次更改文档,只需一条命令,即可更新线上网站。


结语


自动化部署还有别的方案比如Github中的Actions,这里就不再详细介绍了。赶快来试试上面的方案吧!部署一个属于自己的博客。


如果有疑问,欢迎留言联系我。



相关文章
|
2月前
|
缓存 前端开发 JavaScript
前端开发的必修课:如何让你的网页在弱网环境下依然流畅运行?
【10月更文挑战第30天】随着移动互联网的普及,弱网环境下的网页性能优化变得尤为重要。本文详细介绍了如何通过了解网络状况、优化资源加载、减少HTTP请求、调整弱网参数和代码优化等方法,提升网页在弱网环境下的加载速度和流畅性,从而改善用户体验。
153 4
|
5月前
|
JSON 前端开发 开发工具
初探在WSL中设置vim前端开发环境
初探在WSL中设置vim前端开发环境
|
2月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
207 1
|
7月前
|
前端开发
windows10 安装node npm 等前端环境 并配置国内源
windows10 安装node npm 等前端环境 并配置国内源
372 3
|
8月前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的办公自动化管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的办公自动化管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
|
4月前
|
缓存 人工智能 前端开发
前端技术博客:探索现代前端开发的奥秘
前端技术博客:探索现代前端开发的奥秘
46 11
|
4月前
|
开发框架 前端开发 JavaScript
【博客开发】前端应用开发环境搭建(可复用)
【博客开发】前端应用开发环境搭建(可复用)
58 5
|
3月前
|
IDE 开发工具 Python
Python自动化操作word--批量替换word文档中的文字
Python自动化操作word--批量替换word文档中的文字
237 0
|
5月前
|
前端开发 JavaScript
【Azure 环境】前端Web通过Azure AD获取Token时发生跨域问题(CORS Error)
【Azure 环境】前端Web通过Azure AD获取Token时发生跨域问题(CORS Error)
|
5月前
|
数据采集 存储 监控
用爬虫技术玩转石墨文档:自动化数据处理与信息提取的新探索
在当今数字化时代,文档协作与管理成为了职场人士日常工作中不可或缺的一部分。石墨文档,作为一款功能强大的在线文档工具,凭借其云端存储、多人实时协作、丰富的文档格式支持等特点,赢得了广泛的用户群体。然而,随着数据量的激增,如何高效地管理和利用这些数据成为了一个亟待解决的问题。此时,爬虫技术便成为了我们玩转石墨文档、实现自动化数据处理与信息提取的强大工具。