/hexo-blog

:smiley: hexo搭建博客示例

Primary LanguageCSSMIT LicenseMIT

hexo-blog

😃 欢迎访问我的博客 在线演示地址https://artdong.github.io/blog

先看看效果

ionic3-awesome.gif

在线预览

点我点我

源码地址

https://github.com/artdong/hexo-blog

初始化Hexo模版引擎

一行代码快速搭建Hexo.NexT主题网站,come on,一起来搭建自己的专属blog吧!

执行安装

进入本机E盘,新建blog目录

  • 第一步,安装hexo环境
  • 第二步,安装下载 Hexo 模版,即初始化Hexo 模版
  • 第三步,进入blog文件夹,执行安装依赖包
  • 第四步,启动Hexo服务
  • 第五步,在浏览器中打开http://localhost:4000/
npm install hexo-cli -g

hexo init blog

cd blog

npm install

hexo server

如果你没有安装npm,请先执行下载安装 https://www.npmjs.com

安装成功执行


npm -v

执行以上步骤之后在浏览器中键入http://localhost:4000 即可看到一个初始状态的模版

修改测试端口号

如果需要修改端口4000,可以在node-modules文件夹下找到hexo-server模块中的index.js:


/* global hexo */

'use strict';

var assign = require('object-assign');

hexo.config.server = assign({
  port: 5000,//自行修改端口号
  log: false,
  ip: '0.0.0.0',
  compress: false,
  header: true
}, hexo.config.server);


修改之后重新执行hexo server即可:

网站基础配置

显示或隐藏Menu菜单

在修改菜单之前你首先要弄清楚当前网站使用的皮肤是哪一个,打开网站根目录 config_yml

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

其中landscape就是你的皮肤框架

然后在网站根目录找到themes/landscape这里面就会有你菜单想的配置,同时这里面也有一个 config_yml,为了区分,我们索性把站点下的配置文件称为站点配置yml,皮肤框架下的配置文件称之为皮肤配置yml

OK,打开皮肤配置yml你会看到一些简短的配置,其中第一条就是我们的菜单栏配置

# Header
menu:
  Home: /
  Archives: /archives

修改Home主菜单,修改Archives文章,刷新浏览器http://localhost:4000 即可看到效果

配置站点基础信息

打开站点配置yml

# Site
title: 标题
subtitle: 副标题
description: 描述
author: 作者
language: zh-Hans
timezone:

刷新浏览器 http://localhost:4000

设置rss

在站点根目录执行安装hexo-generator-feed

npm install hexo-generator-feed  --save-dev

站点配置yml中配置插件,为了快速的找到配置项,可以放到文件的结尾

plugins: hexo-generator-feed

feed:
  type: atom ##feed类型 atom或者rss2
  path: atom.xml ##feed路径
  limit: 20  ##feed文章最小数量

点击RSS按钮,会出现如下提示,前提是你的浏览器有rss功能,我本地使用的是rss feed reader

设置本地全局搜索

安装下载hexo-generator-searchdb模块

npm install hexo-generator-searchdb --save-dev

站点配置yml需要配置

search:
  path: search.xml
  field: post
  format: html
  limit: 10000

皮肤配置yml需要配置

local_search:
  enable: true

当然你会发现并没有起作用,这是因为当前landscape并不支持本地搜索,后续将介绍NexT主题

使用命令生成静态文件

您可执行下列的其中一个命令,让 Hexo 在生成完毕后自动部署网站,两个命令的作用是相同的。生成的文件在网站public目录下

hexo generate --deploy
hexo deploy --generate

可缩写为:

hexo g -d
hexo d -g

NexT主题

下载安装NexT模版

在github上下载NexT主题源码

NexT主题源码的源码整个复制到你的站点目录下的themes/next目录下

修改站点配置yml来更改主题

文章上面有讲到,当前我们的主题使用的是landscape需要修改为next

重新启动服务

刷新页面查看效果

学习并使用NexT主题配置

打开next皮肤配置yml,你会看到很多我们不明白的配置项,根据注释可以读出其中配置的含义。

根据语言配置菜单栏语言

打开next皮肤配置yml文件,找到languages文件夹

点开zh-Hans.yml其中的配置项就是已经翻译的文本,网站会根据你站点配置yml中的语言配置来去读取对应的语言文件

打开你next皮肤配置yml你会看到菜单栏基础配置:

menu:
  home: / || home
  #about: /about/ || user
  #tags: /tags/ || tags
  #categories: /categories/ || th
  archives: /archives/ || archive
  #schedule: /schedule/ || calendar
  #sitemap: /sitemap.xml || sitemap
  #commonweal: /404/ || heartbeat

发现homearchives菜单是开启的,现在我们全部开启,只需要去掉前面的#,刷新浏览器

menu:
  home: / || home
  about: /about/ || user
  tags: /tags/ || tags
  categories: /categories/ || th
  archives: /archives/ || archive
  schedule: /schedule/ || calendar
  sitemap: /sitemap.xml || sitemap
  commonweal: /404/ || heartbeat

尝试修改站点配置yml语言,重启服务后刷新浏览器

language: zh-tw

配置站内搜索

安装下载hexo-generator-searchdb模块

npm install hexo-generator-searchdb --save-dev

站点配置yml需要配置

search:
  path: search.xml
  field: post
  format: html
  limit: 10000

皮肤配置yml需要配置

local_search:
  enable: true

配置rss

配置同见 2.3. 设置rss

配置标签(tags)

添加标签其实就是在你的source文件夹下新建一个page页面而已,比如菜单上的tagsabout或者categories都是一样的,执行命令

hexo new page "tags"

会在source目录下生成一个对应的文件夹,其中有index.md文件,打开会看到一些基础配置:

---
title: tags
date: 2017-10-24 12:02:51
---

配置分类(categories)

hexo new page "categories"

会在source目录下生成一个对应的文件夹,其中有index.md文件,打开会看到一些基础配置:

---
title: categories
date: 2017-10-24 12:02:51
---

配置站点基础信息

配置头像

next皮肤配置yml中可以配置远程地址,也可以是本地资源地址

# Sidebar Avatar
# in theme directory(source/images): /images/avatar.gif
# in site  directory(source/uploads): /uploads/avatar.gif
avatar: 头像地址
配置站点描述

站点配置yml文件中,找到menu/description就是当前站点的描述

description: 站点描述
配置第三方跳转链接

next皮肤配置yml中,找到social配置项

social:
  GitHub: https://github.com/yourname || github
  E-Mail: mailto:yourname@163.com || envelope
  QQ: http://wpa.qq.com/msgrd?v=3&uin=yourqq&site=在线客服&menu=yes || qq
  #Google: https://plus.google.com/yourname || google
  #Twitter: https://twitter.com/yourname || twitter
  #FB Page: https://www.facebook.com/yourname || facebook
  #VK Group: https://vk.com/yourname || vk
  #StackOverflow: https://stackoverflow.com/yourname || stack-overflow
  #YouTube: https://youtube.com/yourname || youtube
  #Instagram: https://instagram.com/yourname || instagram
  #Skype: skype:yourname?call|chat || skype
友情链接

next皮肤配置yml中,找到links配置项

links_icon: link
links_title: Links
links_layout: inline
links:
  friend1:
  friend2:
  friend3:

配置阅读次数(使用第三方服务)

leancloud作为装逼神器确实不错,可以随意修改当前文章的阅读次数

# Show number of visitors to each article.
# You can visit https://leancloud.cn get AppID and AppKey.
# 使用第三方服务 LeanCloud 查看文章阅读量
leancloud_visitors:
  enable: true
  app_id:
  app_key:

配置评论(使用第三方服务)

在disqus官网 http://www.disqus.com 注册一个帐号添加应用之后可获得一个名称,作为你的shortname

# Disqus
disqus:
  enable: true
  shortname: 你的名称
  count: true

配置站点统计(使用第三方服务)

百度站点统计 http://tongji.baidu.com/web/welcome/login

# Baidu Analytics ID
# 注意: baidu_analytics 不是你的百度 id 或者 百度统计 id
baidu_analytics: 327573ae29bff3e49a0152fd0be5e1c2

当前文章是否启用评论配置

如果不需要当前页面或这文章不启用评论,则只需要添加以下配置:

---
title: tags
date: 2017-10-24 12:02:51
comments: false
---

自定义配置

在每个文章的最后加上版权声明

  • 新建 passage-end-tag.swig 文件

在路径 \themes\next\layout\_macro中添加passage-end-tag.swig文件,其内容可以自定义:

{% if theme.passage_end_tag.enabled %}
<div>
<div style="text-align:center;color: #ccc;font-size:14px;">
------ 本文结束 ------</div>
<br/>

<ul class="post-copyright" style="margin: 2em 0 0; padding: 0.5em 1em;border-left: 3px solid #ff1700;background-color: #f9f9f9;list-style: none; ">
  <li class="post-copyright-author">
    <strong>本文作者:</strong>
    ArtDong
  </li>
  <li class="post-copyright-license">
    <strong>版权声明: </strong>
    本博客所有文章除特别声明外,转载请注明出处!
  </li>
</ul>
</div>
{% endif %}


  • 修改 post.swig 文件 在\themes\next\layout\_macro\post.swig中,post-body之后,post-footer之前添:
  {% if not is_index %}
    {% include 'passage-end-tag.swig' %}
  {% endif %}
  • next主题配置yml中添加字段
# 文章末尾添加“本文结束”标记
passage_end_tag:
  enabled: true

结束语

跟着我的步骤可以很快的搭建一个属于自己的博客站点,当然hexo.next远远不知这些配置项,有兴趣的同学可以自己看看里面的配置。

hexo官网地址 http://theme-next.iissnan.com/getting-started.html


经典前端面试题每日更新,欢迎参与讨论,地址:https://github.com/daily-interview/fe-interview