「奇怪的教程」年轻人的第一个博客搭建指南
开始前要说的话
当你有意识想要为自己搭建一个个人博客时,我相信你已经步入了开发者这扇门,也许你的技术没有非常强劲,或者你和我一样对于前端技术了解的很少,你在接下来的搭建过程中可能会出现一些问题,这些问题很有可能没有完全的记录在我的教程中,但是请一定要记得:
::: tip
遇见了问题请不要抱怨,尝试自己解决他,利用你的翻译软件和搜索软件,找到问题的关键,处理它,自己动手把坑填上 :)
:::
用到的技术和知识
vuepress:基于Markdown的前端网站生成器,awesome,简单易用,不需要掌握太多前端技术也可以快速搭建
vuepress-theme-hope:一个具有强大功能的 vuepress 主题,封装好了很多功能,即使前端不是很熟悉,也可以快速上手
markdown语法:这个网上教程很多,语法也很简单,本文也是使用markdown进行撰写的,这个必须要了解
官方文档
最好的教程当然是官方文档
quickstart
安装nodejs
下载nodejs,要求版本大于8.6,傻瓜式安装,一路next
# 测试安装是否成功
# 如果win10环境提示无此命令,先检查环境变量中nodejs命令的路径是否正常,然后尝试重启电脑
node -v
npm -v
# 正常输出代表安装成功
helloworld
# 选择一个合适的路径,创建并进入一个新目录
mkdir vuepress-starter && cd vuepress-starter
# 初始化项目,-y会自动帮你生成好相关内容
# npm不太懂没关系,我们的重心不在这,大致理解就是我们的项目基于npm运行,这一步是初始化
npm init -y
# 安装vuepress
# 如果你的环境安装正确
# 这一步结束你会发现给你的目录生成了一些文件
# 不要慌,现在你可以不知道这些文件和目录的作用
npm install -D vuepress
# 创建docs目录
# 需要你记住的是
# docs简单理解就是放你各种工作文件的地方,类似于java的src目录
右击在当前目录新建一个docs文件夹 or mkdir docs
# 进入docs,新建一个README.md文件
# 在你的README.md中写上: # Hello World!
# 修改你主目录的package.json文件,设置你的启动命令
# 你可以不配置,但是我推荐你这么做,因为配置了这是能少打几个字,方便点
# 找到scripts,不要动里面的其他东西,往里面加两行
"dev": "vuepress dev docs",
"build": "vuepress build docs"
# 然后启动!
npm run dev
# 等待启动完成,你的终端会给你一个提示,让你访问localhost:8080
# Hello World !
目录结构
现在你已经尝试过了Hello World,但这远远还不够,想要更深一步去搭建一个炫酷的博客,你还需要知道vuepress的目录结构
否则你无法继续向下学习,你可以不需要死记硬背这些目录结构的作用,大致的浏览
重点记住docs,docs/.vuepress/config.js即可,其他的等你遇到了再来看看也不迟
你可能会差异,我生成的项目中没有这些文件或者目录,没关系,自己创建一个即可
.
├── 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
目录作用的描述:
- docs/.vuepress: 用于存放全局的配置、组件、静态资源等。
- docs/.vuepress/components: 该目录中的 Vue 组件将会被自动注册为全局组件。
- docs/.vuepress/theme: 用于存放本地主题。
- docs/.vuepress/styles: 用于存放样式相关的文件。
- docs/.vuepress/styles/index.styl: 将会被自动应用的全局样式文件,会生成在最终的 CSS 文件结尾,具有比默认样式更高的优先级。
- docs/.vuepress/styles/palette.styl: 用于重写默认颜色常量,或者设置新的 stylus 颜色常量。
- docs/.vuepress/public: 静态资源目录。
- docs/.vuepress/templates: 存储 HTML 模板文件。
- docs/.vuepress/templates/dev.html: 用于开发环境的 HTML 模板文件。
- docs/.vuepress/templates/ssr.html: 构建时基于 Vue SSR 的 HTML 模板文件。
- docs/.vuepress/config.js: 配置文件的入口文件,也可以是 YML 或 toml。
- docs/.vuepress/enhanceApp.js: 客户端应用的增强。
基础配置
现在你已经尝试过了HelloWorld,同时也大致浏览了一遍vuepress的目录结构以及他们的作用,知道了docs目录和config.js的作用
我们尝试做一些更加有趣的配置,记住docs/.vuepress/config.js这个是我们项目的核心配置文件,绝大多数的内容配置(如导航栏,侧边栏,首页的图标,标题等等)都是在这里进行配置的,如果你还没有这个目录,请手动在docs目录下新建.vuepress目录,并新建config.js文件
module.exports = {
title: '你的第一个vuepress博客', // 定义了你博客左上角的标题
head: [
['link', { rel: 'icon', href: '/logo.jpg' }], // 自定义你博客head中的icon
],
themeConfig: {
nav:[ // 导航栏配置
{text: 'Java', link: '/java/' },
{text: 'Spring', link: '/spring/'},
{text: '数据库', link: '/db/'}
],
}
};
配置并保存,尝试启动(npm run dev)你的项目,就会得到下面这样一个简单的博客框架
ok,这样我们至此我们已经成功的创建了一个简单的博客,虽然比较简单,但是这也算是迈出了很大的一步
基于markdown的静态页面
vueperss基于markdown,所以我们日后写博客的文件也全部都需要用markdown
markdown文件可以简单理解成html文件,我们要把他们存在docs目录下,不要问为什么,vuepress就是这么规定的
# 比如我写了两篇java博客,两篇spring博客,那么为它们分好类进行存放,目录结构是这样的
.
├── docs
│ ├── .vuepress (可选的)
│ │ ├── config.js (可选的)
│ ├── java
│ │ └── blog1.md
│ │ └── blog2.md
│ │ └── README.md
│ ├── spring
│ │ └── blog1.md
│ │ └── blog2.md
│ ├── README.md # 首页
└── package.json
相对的我们需要访问这些文件的路径就如下
java下的blog1 : /java/blog1/
我们还注意到java下有一个README.md
在vuepress中约定,目录下的README.md文件的路径就是该目录
所以java下的README的访问路径就是 /java/
到这里你明白了你的HelloWorld是怎么来的了吗 :)在docs目录下创建README.md,访问路径就是/,也就是首页
撰写文章
上面我们已经知道了docs目录是关键,所以直接在docs目录下新建你的分类文件夹,然后创建markdown文件写文章即可,哦天哪,真是太简单了!!!
主题配置
了解了vuepress的基础配置后,我们继续尝试一些更加炫酷的操作,主题配置
vuepress提供了强大的主题配置功能,使得使用者可以diy自己的主题并分享
下面分别对于系统默认主题的配置以及其他用户diy的主题使用进行介绍
默认主题
默认的当你保持你的config.js,不去进行theme的相关配置时,使用的就是默认的主题,其效果预览可以参照vuepress的官方网站
这里是vuepress官方网站提供的主题配置的相关文档,可以说记录的十分详细,我这里就简单的对其进行使用,带你体验一下
::: warning
此时你必须要已经大致明白HelloWorld是如何出现的,才能继续的无障碍向下学习
:::
默认的主题提供了一个首页(Homepage)的布局 (用于 vuepress主页)。
想要使用它,需要在你的根级 README.md
的 YAML front matter 指定 home: true
。以下是一个如何使用的例子:
什么是YAML front matter,简单理解就是用在markdown文件的开头配置
---
home: true # 指定为首页文件
heroImage: /hero.png
heroText: Hero 标题
tagline: Hero 副标题
actionText: 快速上手 →
actionLink: /zh/guide/
features:
- title: 简洁至上
details: 以 Markdown 为中心的项目结构,以最少的配置帮助你专注于写作。
- title: Vue驱动
details: 享受 Vue + webpack 的开发体验,在 Markdown 中使用 Vue 组件,同时可以使用 Vue 来开发自定义主题。
- title: 高性能
details: VuePress 为每个页面预渲染生成静态的 HTML,同时在页面被加载的时候,将作为 SPA 运行。
footer: MIT Licensed | Copyright © 2018-present Evan You
---
修改好后重新运行你的项目,你会看到:(图片丢失是因为我们没有图片)
是不是很熟悉,这和vuepress的首页几乎一样
恭喜啊,你的博客变得越来越好看了,事情开始变得有趣了起来 :)
::: tip
然后就是更多的关于导航栏、侧边栏等等的一系列的DIY配置,这里不做详细介绍
请移步主题配置进行更深的学习,你可能会遇到很多的坑,别灰心,尝试解决它们
:::
使用第三方主题
主题的使用需要先将主题文件进行安装,一行命令即可
这里我选择了我个人比较喜欢的一款主题vuepress-theme-hope进行介绍
一般情况下,第三方主题都有详细的文档,傻瓜式的一步步教你如何进行博客搭建
这里我也是仿照vuepress-theme-hope的文档进行简单介绍
# 安装主题
# 切换到项目根目录
npm i -D vuepress-theme-hope
# 安装好后,注意你的node_modules目录,会多出一个vuepress-theme-hope目录,代表安装成功
// 修改你的config.js,让他变成这样
// .vuepress/config.js
const { config } = require("vuepress-theme-hope");
module.exports = config({
// your config here
});
我之所以喜欢这个主题,是因为它对于新手很友好,它提供了 现成的模板直接下载使用即可,我们只要在他的基础上修改就可以了
vuepress-theme-hope 模板直接下载,然后进入目录npm init -y初始化下,然后启动即可,你想要的他都帮你配置好了!
怎么样是不是很简单!
更多的关于这款主题的配置,也请移步文档进行学习,因为文档写的很详细,新手阅读也几乎没有难度,所以还等什么,赶紧来试试
部署到Gitee
创建一个gitee仓库
这里要注意你的仓库名,保证和你的用户名一致
因为我最后希望你的访问路径是 :https://你的用户名.gitee.com
build你的项目
还记得最开始我们修改的package.json吗,里面除了dev还有一个build
哦对了,你还需要指定一下你的构建文件输出目录。在config.js中进行配置
在config中添加一个配置:dest: "./dist", // 配置build之后的文件输出目录,像这样
尝试运行 npm dev build,等待执行完成,你的项目就构建好了输出在了当前的dist目录中
部署脚本编写
接下来,在根目录下创建一个deploy-gitee.sh,输入:
#!/usr/bin/env sh
# 确保脚本抛出遇到的错误
set -e
# 生成静态文件
npm run build
# 进入生成的文件夹
cd dist
git init
git add -A
git commit -m 'deploy'
# 如果部署到 https://{USERNAME}.github.io
# 下面这里的url那一段你直接在你的git仓库那里复制出来粘贴就可以
git push -f git@gitee.com:xxxx/xxxx.git master
cd -
部署上线
切换到命令行,执行该脚本,如果windows不能执行,尝试在git bash中执行
执行完成后你的项目就会传到gitee你的仓库中
然后关键点来了,选择你仓库中的服务 -> gitee pages
点击发布就好了,我这里已经发布了,所以这里是更新按钮!!
然后你就可以点击上面显示的域名进行博客的访问啦!!!!!!!!!
像这样
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。