安装

// 通用安装
// 依赖ruby,所有要先装上ruby
sudo gem install jekyll bundle

// ubuntu上安装
sudo apt install jekyll

常用命令

// 启动一个服务,会自动更新改动的,在书写博客的时候开着相当方便
jekyll serve

// 构建静态页面,会生成 _site 文件夹
jekyll build

目录介绍

名称 说明 用法
_layouts 布局文件 比如博客详情页面,在md文件头部要加上的 layout: post 就是用的 _layouts/post.html 页面
_posts 博客原文件目录 格式为 markdown 后缀的博客原文件所在目录
_includes 在页面里引入的页面 可以直接使用 include 引用

配置文件

jekyll 默认启动加载 _config.yml 文件,在页面里获取配置在 _config.yml 里的值用的是 site.xxx

比如,在 _config.yml 文件里加入一个变量 github_username: tomoya92 那么在页面上就可以用 chenyongze 来获取它的值

permalink: /:year/:month/:day/:title/ 表示访问博客的路径地址格式,比如 _posts/2017-06-03-hello.md 构建后的访问地址就是 /2017/06/03/hello/ 如果定成 permalink: /:title/ 那么访问地址就是 /hello/ 这里就有个问题,万一两个文件名字是一样的,就是前面的日期不同,那就会出现访问路径一样的现象,会不会报错,我没试过,不过如果带上日期,这样的概率就小多了,还是建议带上,这样在搜索引擎抓到页面后,路径上也有个时间,对需要的人也是一种帮助

博客的相关变量取值

变量 说明
post.title 博客title
post.content 博客内容,已经将markdown转成html的内容
post.url 博客地址,就是访问详情的地址

博客简介

可以在 _config.yml 里配置一个 excerpt_separator: "\n\n\n\n" 这里配置了四个换行,也可以换成其它的分割符号,然后在博客原文件里要分割的位置加上四个换行,就可以在列表里看到分割部分的内容了,这样如果一篇博客比较长的话,可以在博客前面写上简介,分割一下,看起来好看的多

列表分页

_config.yml 里配置上

gems: [jekyll-paginate]
paginate: 6

paginate 是每页要显示的条数

这样在页面里遍历就可以用 paginator.posts 来获取分页列表,如下

变量 说明
paginator.previous_page 是否有前一页
paginator.next_page 是否有上一页
paginator.page 当前页
paginator.total_pages 总页数
paginator.previous_page_path 前一页的路径地址
paginator.next_page_path 后一页的路径地址

分页地址是 /page + num 比如 /page1 表示第一页 /page4 表示第4页,所以最后一页就是 /page

模板语法

只介绍两种 if for

if用法

for用法

另外 for 里还可以设置偏移量,类似分页功能

Github Pages托管

将开发好的代码都push到github上就可以了,怎么push,可以百度一下,也可以fork本博客来改

注意事项

博客的文件名必须要写成 YEAR-MONTH-DAY-TITLE.md 就是 年-月-日-名称.md 如果不是这个,它不能解析

参考

本博客就是基于jekyll写的,所有上面提到的,在这个博客里都可以找到

原文链接: https://chenyongze.github.io/2017/06/03/jekyll-blog/