最近业余时间利用hexo为自己搭建一个高度自定义的个人站点,站点发布在github上,访问地址为:https://cqhaibin.github.io/。本博客简单介绍实现此站点的过程。效果图如下

构建此站点最初的目的主要方便自己使用本人开发的tomato time这个小工具。然后在实施的过程中加入的自己自己琢磨写的vueManager。

hexo的介绍和常用内容总结

hexo实现了通过markdown生成静态站点的能力,提供了高度定制化的能力。

1. hexo常用命令

命令名 说明
hexo init 初始化一个hexo项目
hexo server 启动本web服务,用于开发阶段
hexo g 生成静态网页
hexo d 部署网页
hexo clean 清理缓存
hexo new "postName" 新建文章
hexo new page "pageName" 新建页面

2. hexo模板介绍

archive.ejs归档列表页模板,归档可以按照年份+月份实现的,list_archives显示列表

模板文件名 说明
layout.ejs 模板的入口文件,也是整个站点的入口文件
index.ejs

首页,布局文件<%- body %>默认输出嵌入的页面

post.ejs 文章详细页
page.ejs 页面
archive.ejs 归档列表页模板,归档可以按照年份+月份实现的,list_archives显示列表
category.ejs 分类显示页
tag.ejs 标签页

hexo的模板解析,以layout.ejs为入口,所有静态页面(如:文章、页面、首页、标签、归档、分类等)都会以layout.ejs为模板。所以每个页面的公共部分应该在写layout.ejs中(如页头、页脚等)。

3. hexo-asset-image

此插件实现markdown引用的本地图片,在markdown转换为html也能被正确引用。

hexo模板开发

根据上述 “hexo模板介绍”,我们可以很较为轻松的开发出自己的模板,模板文件说明

模板文件夹、配置文件 说明
layout 相关ejs模板信息,用于生成html时使用
script 此文件夹下的.js文件,作为hexo插件 的一种扩展存在,在编译过程中起作用
source 此文件下的文件或文件夹,在编译过程中会保持不变,供开发者使用
languages 多语言包
_config.yml 针对当前模板的配置文件,配置文件中的信息可以被ejs模板访问

说明:

1. 本示例模板使用的stylus作用css的预编译语言。

hexo插件开发

1. 插件需要入在node_moduels文件夹下,必须有.js和.package.json文件(也就是一个标准npm包即可).

js文件:

'use strict'
console.log('hexo-filter-list start success....');
var core = {
findglyph: function(txt, glyph){
var num = 0;
while(txt.charAt(num) == glyph){
num++;
}
return num;
}
}
hexo.extend.filter.register('before_post_render',function(data){
//正则获取标题,并赋值给data对象
var regex = new RegExp("(#{1,6})\\s*(.?)(\\S*)", "g");
var titles = [], tmp;
while((tmp = regex.exec(data.content)) != null){
var txt = tmp[0], level = core.findglyph(txt, '#');
var val = {
level: level,
title: txt.substring(level).replace(/(^\s*)/g, '')
}
console.log(val);
titles.push(val);
}
data.headers = titles;
});

package.json文件

{
"name": "hexo-filter-list",
"main": "index",
"version": "1.0.0.0"
}

注意:

1. hexo的事件监听都是有缓存的,内容不变,不会触发相应的事件。

2. 本示例的下载包中不包含node_modules,需要手动放将hexo-filter-list放在node_moduels中

3. 必须在根目录的package.json文件的依赖荐中加入hexo-filter-list包,如下

"dependencies": {
"hexo": "^3.2.0",
"hexo-filter-list": "^1.0.0.0",
}

总结

本文只是hexo使用的初级探索,其中关于hexo的说明存在问题的地方希望各位朋友指正。如果你需要使用hexo,还是建议都看他的官方文档。

下载hexo-filter-list插件                下载hexo示例

hexo配置自己的博客站点的更多相关文章

  1. 使用hexo和coding建立静态博客站点

    背景 由于工作性质的原因,做技术的总想记录和分享一下自己的学习和成长历程,向这世界证明我来过.写文章,发博客,一开始使用51cto,广告太多,看起来让人很痛苦:接着试用了博客园,广告少一些,但感觉还是 ...

  2. github+hexo搭建自己的博客网站(六)进阶配置(搜索引擎收录,优化你的url)

    详细的可以查看hexo博客的演示:https://saucxs.github.io/ 绑定了域名: http://www.chengxinsong.cn hexo+github博客网站源码(可以clo ...

  3. 基于Hexo和Github搭建博客

    搭建自己的个人博客. 准备工作 确保电脑需要已下载安装node和npm.查看安装是否成功,windows只需在命令行输入以下两条命令即可. 1 2 $ node -v $ npm -v 安装hexo ...

  4. 《Hexo+github搭建个人博客》

    <Hexo+github搭建个人博客> 文/冯皓林 完稿:2016.4.22-2016.4.23 注意:本节教程只针对Windows用户.本教程由无人赞助,赞助写出. <Hexo+g ...

  5. 可能是最详细的 Hexo + GitHub Pages 搭建博客的教程

    前言:博主目前大三,Web 前端爱好者.写博客的好处,不是为了写而写,而是一个记录思想的过程.不要考虑它能带给你什么,而是你自己从中收获了什么. 最近刚好有空,于是就参照网上的各种教程,搭建了一个博客 ...

  6. github+hexo搭建自己的博客网站(一)基础入门

    github提供的page,hexo提供的静态博客文档,这样可以搭建一个自己的一个博客网站. 使用github pages服务搭建博客的好处有: 全是静态文件,访问速度快: 免费方便,不用花一分钱就可 ...

  7. github+hexo搭建自己的博客网站(七)注意事项(避免read.me,CNAME文件的覆盖,手动改github page的域名)

    详细的可以查看hexo博客的演示:https://saucxs.github.io/ 绑定域名可以查看:http://www.chengxinsong.cn 可以查看在github上生成的静态文件(如 ...

  8. hexo建立github,gitcafe博客并实时同步的要点

    把hexo博客的源码和生成的页面实时同步到github和gitcafe. 用搜索引擎搜索"github 博客"等关键字会出现大量很好的文章教小白一步步搭建.我这里列出一些关键点,希 ...

  9. 使用Node.js+Hexo+Github搭建个人博客

    一.为什么要花时间去搭建个人博客? 首先说说为什么我想要尝试着去搭建属于自己的Blog,古人云:“好记性不如烂笔头”.一开始我把笔记做在本子上.电脑上,发现要用的时候特别地不方便,而且越记越多.越多越 ...

随机推荐

  1. SharePoint修改左上角文字的命令行

    $webapp = Get-SPWebApplication “http://test-spweb1” --需要修改的站点$webapp.SuiteNavBrandingText = “XXXXXX” ...

  2. python tesserocr ImportError: dll loading failed 一个不常遇见的错误,以及简单的python安装方法~

    废话不多说了,这是写给小白的了. 本人有c#,c/c++开发经验,最近因为偶然的原因,开始接触python,遇到一个棘手的问题,一位朋友在安装tesserocr 包后遇到一个错误,重新安装数次不能解决 ...

  3. redis的两种安装方法

    原:https://www.cnblogs.com/caokai520/p/4409712.html C# Redis   概念 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦 ...

  4. vue 事件修饰符

    1.用.stop来阻止冒泡(点击click按钮之后,先执行clickBtn2方法,然后执行clickBtn1方法,.stop命令阻止了clickBtn1方法的执行) 2.使用.prevent命令来阻止 ...

  5. Codeforces 939E Maximize! (三分 || 尺取)

    <题目链接> 题目大意:给定一段序列,每次进行两次操作,输入1 x代表插入x元素(x元素一定大于等于之前的所有元素),或者输入2,表示输出这个序列的任意子集$s$,使得$max(s)-me ...

  6. JIRA

    https://www.jianshu.com/p/8c14b52ce692 JIRA这个工具接触有好几年了,在多个海外项目上都用过这个工具.去年又在项目上深度使用后就有点爱不释手了,回国后也在找机会 ...

  7. 2018-2019-2 网络对抗技术 20162329 Exp1 PC平台逆向破解

    目录 1.实践目标 2.实验内容 2.1 手工修改可执行文件,改变程序执行流程,直接跳转到getShell函数. 2.2 利用foo函数的Bof漏洞,构造一个攻击输入字符串,覆盖返回地址,触发getS ...

  8. Python序列化proto中repeated修饰的数据

    一.repeated修饰复合数据结构,即message时 1.使用message的add方法初始化新实例 2.分别对新实例中的每个元素赋值:或使用CopyFrom(a)拷贝a中的元素值 message ...

  9. Unity-修改Debug日志文本颜色

    Unity开发过程中Debug信息是非常重要的,但是千篇一律的白色字符不能迅速找出想要的信息,添加些字体颜色是个很好的办法,比如: AppDebug.Log("<color=#ff84 ...

  10. Mac_mac下使用ll等指令

    Linux有ll等命令,切换到MAC下这些指令是没有的 其实就是别名,用ls -alF也能做到 添加方法: vim ~/.bash_profile 输入一下内容 alias ll='ls -alF'a ...