hexo小白学习详细教程

hexo是一个快速、简介、高效的博客框架,支持Markdown,拥有丰富的插件系统,常与GitHub等代码托管平台一起构建个人博客网站。

官方链接


中文官网

安装及使用


前提:

电脑中需要已安装Git、Node.js(6.9以上)

安装:
$ npm install hexo-cli -g//安装
建站
$ hexo init <目录名>//初始化博客项目(最新版本已经可以在这一步安装依赖)
$ cd <目录名>//进入博客
$ npm install//安装依赖

命令完成后的目录如下:


image.png

文件夹说明:

|-- demo//项目跟目录名
    |-- .gitignore//git时忽略的文件或目录
    |-- package-lock.json
    |-- package.json//应用程序的信息
    |-- _config.yml//网站的配置信息
    |-- scaffolds//模板文件夹,Hexo的模板是指在新建的markdown文件中默认填充的内容。
    |   |-- draft.md
    |   |-- page.md
    |   |-- post.md//博文模板
    |-- source//资源文件夹,存放用户资源
    |   |-- _posts//博文目录
    |       |-- hello-world.md//博文
    |-- themes//主题文件夹,Hexo 会根据主题来生成静态页面
        |-- landscape.//默认主题
            ...

此时package.json中内容如下:

{
  "name": "hexo-site",
  "version": "0.0.0",
  "private": true,
  "hexo": {
    "version": ""
  },
  "dependencies": {
    "hexo": "^3.8.0",
    "hexo-generator-archive": "^0.1.5",
    "hexo-generator-category": "^0.1.3",
    "hexo-generator-index": "^0.2.1",
    "hexo-generator-tag": "^0.2.0",
    "hexo-renderer-ejs": "^0.3.1",
    "hexo-renderer-stylus": "^0.3.3",
    "hexo-renderer-marked": "^0.3.2",
    "hexo-server": "^0.3.3"
  }
}

修改配置:

配置修改教程:配置
修改配置文件中必须修改的几项,其余可根据配置自行修改:

  • url:网站地址,必须修改,此处博文是托管在github上,故此使用http://youname.github.io格式作为网站名字
  • language:语言,设置中文,根据需要修改,中文为zh-CN
    注意:配置值与配置名需要隔一个空格,否则会编译报错
# Hexo Configuration
## Docs: https://hexo.io/docs/configuration.html
## Source: https://github.com/hexojs/hexo/

# Site
title: Hexo小白的博客
subtitle:
description:
keywords:
author: Hexo小白
language: zh-CN
timezone:

# URL
## If your site is put in a subdirectory, set url as 'http://yoursite.com/child' and root as '/child/'
url: http://emmaHuang.github.io
root: /
permalink: :year/:month/:day/:title/
permalink_defaults:

# Directory
source_dir: source
public_dir: public
tag_dir: tags
archive_dir: archives
category_dir: categories
code_dir: downloads/code
i18n_dir: :lang
skip_render:

# Writing
new_post_name: :title.md # File name of new posts
default_layout: post
titlecase: false # Transform title into titlecase
external_link: true # Open external links in new tab
filename_case: 0
render_drafts: false
post_asset_folder: false
relative_link: false
future: true
highlight:
  enable: true
  line_number: true
  auto_detect: false
  tab_replace:
  
# Home page setting
# path: Root path for your blogs index page. (default = '')
# per_page: Posts displayed per page. (0 = disable pagination)
# order_by: Posts order. (Order by date descending by default)
index_generator:
  path: ''
  per_page: 10
  order_by: -date
  
# Category & Tag
default_category: uncategorized
category_map:
tag_map:

# Date / Time format
## Hexo uses Moment.js to parse and display date
## You can customize the date format as defined in
## http://momentjs.com/docs/#/displaying/format/
date_format: YYYY-MM-DD
time_format: HH:mm:ss

# Pagination
## Set per_page to 0 to disable pagination
per_page: 10
pagination_dir: page

# Extensions
## Plugins: https://hexo.io/plugins/
## Themes: https://hexo.io/themes/
theme: landscape

# Deployment
## Docs: https://hexo.io/docs/deployment.html
deploy:
  type:

运行
$ hexo server//运行本地服务

在浏览器打开“http://localhost:4000/

image.png

可以看到小站已经建起来了。

使用

用hexo进行写博文的命令使用如下:

  1. 新建博文
hexo new "my first blog"//有逗号必须使用引号括起来

source/_posts/下生成文件my-first-blog.md如下:

---
title: my first blog
date: 2019-05-11 16:20:56
tags:
---

这里使用---分割的区域叫做“Front-matter”,用于指定这篇博文的变量
此时如果运行了hexo server,刷新浏览器时可看到新建的博文:

image.png

可手动修改Front-matter

---
layout:
title: my first blog
date: 2019-05-11 16:20:56
updated:
comments:
tags:
- introduction
- hexo
categories:
- Diary
---

tags表示标签, categories表示分类,修改之后刷新如下:


image.png
  1. 生成静态文件
hexo generate//简写hexo g 
hexo g -d//文件生成后立即部署网站
hexo g -w//监视文件变动
  1. 发表草稿
hexo publish "my first blog"
  1. 启动本地服务器
hexo server [-p 4001] //可以修改端口
  1. 部署网站
hexo deploy
hexo d//简写
hexo d -g//部署之前先生成静态文件
  1. 清除缓存(db.json)和已经生成的静态文件(public),当发现对站点的更改无效时,比如更换主题后,执行此命令
hexo clean
  1. 列出网站资料
hexo list
image.png
部署

hexo提供一键部署的功能,命令:

hexo deploy//简写hexo d

在开始之前,需要安装deployer和在_config.yml中进行配置:
安装deployer(这里只记录Git方式)

npm install hexo-deployer-git --save

修改配置

# Deployment
## Docs: https://hexo.io/docs/deployment.html
deploy: 
  type: git
  repo: git@github.com:emmaHuang1992/emmaHuang1992.github.io.git
  branch: public
  message: publish blog

生成站点文件并推送远程库:

hexo clean//清除站点文件
hexo deploy//重新生成站点文件并推送

推送之前,在库设置(Repository Settings)中将默认分支设置为_config.yml配置中的分支名称。稍等片刻,站点就会显示Github Pages中

可设置两个分支(根据自己的习惯自行配置):

  • master:存放源代码
  • public:存放编译部署后的站点文件

开始在github中新建代码仓库:

  1. 新建的repository名字要与账号对应,格式:youname.github.io
  2. 生成本机ssh
ssh-keygen -t rsa -C "email@xx.com"

在目标目录中找到id_rsa.pub打开

image.png

复制内容到github对应库中的settings->Deploy keys->Add new->复制粘贴公钥->选中确认写入权限->添加
image.png

然后执行以下命令:

$ eval "$(ssh-agent -s)"
$ ssh-add ~/.ssh/id_rsa
$ clip < ~/.ssh/id_rsa.pub
$ ssh -T git@github.com//测试下公钥有没有添加成功

主题配置


如果不想使用默认的主题,也可以自己下载一个新的主题,放在themes目录下,并修改 _config.yml 内的 theme 设定,即可切换主题。
拿使用广泛的next主题为例:next使用教程

  1. 在themes目录下克隆next主题
git clone https://github.com/iissnan/hexo-theme-next themes/next
  1. 切换主题
## Themes: https://hexo.io/themes/
theme: next

这时候,重新hexo clean,hexo g,hexo s,就可以看到主题更新啦!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容