应急响应:BootCDN/Staticfile 已被投毒,本主题所有资源均已更换 CDN!
这是 kaeyleo/jekyll-theme-H2O 的增强版,我增加/修改了以下功能:
- 博客界面更加紧凑。
- 将所有依赖项升级,现在你可以使用 Node.js 18 来执行 gulp 了。
- 将大量内容汉化。
- 独立搜索页面,支持跳转 Bing 全文搜索。
- 新增
info
排版,增加“关于博客”页面。 - 夜间模式从定时改为自适应。
- 将 Disqus 换成了 Giscus。
- 文章版权声明可在
_config.yml
中自定义 - 提供了 GitHub Workflow,快速创建 GitHub Pages 博客,无需完整复制主题。
- 支持置顶文章
- 增加 Sitemap
- 将文件夹
_github
复制到你的博客仓库下,改名为.github
。 - 将
_config.yml
复制到你的博客仓库下,完整浏览一遍,并修改配置。 - 复制你想修改的文件到你的仓库,它们会覆盖掉主题提供的文件,比如
favicon.ico
和assets/img/profile.png
。
你可以在 我的博客 预览主题。
以下为原 README,其中标中括号的部分是我修改的:
基于Jekyll的博客主题模板,简洁轻量。
如果你喜欢这个博客模板,请在右上角star一下,非常感谢~
If you like this theme or using it, please give a ⭐️ for motivation ;)
如果想体验手机浏览效果,可以扫一下二维码:
Using your smartphone to scan the QR Code
- 代码高亮
- 夜间模式
- Disqus评论系统 [Plus 已改成 Giscus]
- 粉蓝两种主题色
- 头图个性化底纹
- 响应式设计
- 社交图标
- SEO标题优化
- 文章标签索引
- 博客文章搜索
- 复制文章内容自动添加版权
- Code highlight
- Night mode
- Disqus Comment System [Plus is Giscus]
- Theme color: Blue & Pink
- Hero Patterns
- Responsive design
- SNS Icon
- Title SEO
- Tags system
- Search
- Copyright text on copy event
首先你需要安装Jekyll,请查看文档: 快速指南 [另一份]
如果你已经安装了Jekyll,请检查版本是否为3.0.x [Plus 版支持 3 和 4],你可以使用 gem update jekyll
命令进行升级。
使用 gem install jekyll-paginate
或 sudo gem install jekyll-paginate
安装Jekyll的分页插件。
H2O主题基于Jekyll 3.2.1版本,不同版本之间可能存在部分差异,具体请参考官方更新文档 [经测试,3 和 4 没有差异]
点击右上角Fork按钮在你的Github上创建分支,或者clone
到本地。
git clone https://github.com/kaeyleo/jekyll-theme-H2O.git
[Plus 版:git clone https://github.com/peasoft/jekyll-theme-H2O-plus.git
]
最后,在命令行输入 jekyll server
开启服务,就能在本地预览主题了。
如果需要部署到线上环境,请参照配置文档的 开始 章节进行操作。
- 开始
- 组件
- 个性化
- 高级部分
- 集成服务
- Get Started
- Components
- Style
- Advanced
- Plugins
You can easily get started by modifying _config.yml
你可以通用修改 _config.yml
文件来轻松的开始搭建自己的博客
# Site settings
title: '廖柯宇的独立博客' # 你的博客网站标题
description: '很高兴能在这里与你分享我对技术和生活的思考。' # 站点描述
keyword: '廖柯宇, 廖柯宇的独立博客, 前端, 设计' # 网站关键词
url: 'http://liaokeyu.com' # 站点url
baseurl: ''
# Build settings
paginate: 6 # 一页放几篇文章
paginate_path: 'page:num'
其实大部分参数已经默认配置好了,你只需要通过文档了解它们,然后根据自己的需求去_config.yml
文件里修改即可。
文章一般都放在_posts
文件夹里,每篇文章的开头都需要设置一些头信息:
---
layout: post
title: 'H2O theme for Jekyll'
subtitle: '或许是最漂亮的Jekyll主题'
date: 2017-04-18
categories: 技术
cover: 'http://on2171g4d.bkt.clouddn.com/jekyll-theme-h2o-postcover.jpg'
tags: jekyll 前端开发 设计
---
[Plus 版:你可以添加 top: true
来置顶文章]
博客顶部的导航栏信息需要以下面的格式进行配置:
# Navigation links
nav:
home: '/'
tags: '/tags.html'
导航链接需要写上完整的html文件名 [GitHub Pages 建站可以不加 .html
,但不推荐,那个 s.html
是为了更像动态页面所以没有加],它们都是放于根目录下的,如果自建文件夹[并且你不想把它们放进你的网站],请务必在exclude
参数中增加自建文件夹的文件名:
# Build settings
exclude: ['node_modules', 'dev', 'package.json', '自定义的文件夹名字']
这样做是为了在Jekyll运行时排除某些文件被复制到运行文件_site
里去。
侧边栏分为两个部分:【个人简介】和【推荐标签】。当屏幕宽度小于960px时,侧边栏会被隐藏。
使用阿里的图标管理平台Iconfont整理了一套常用的社交图标用于博客的个人简介上,包括微博、知乎、掘金、简书、Github等十三个网站,并且对鼠标悬停时的样式颜色进行了优化。
配置格式如下:
# SNS settings 配置社交网站url
sns:
weibo: '//weibo.com/lovecolcol'
juejin: '//juejin.im/user/57a6f434165abd006159b4cc'
instagram: '//www.instagram.com/steveliaocn'
github: '//github.com/kaeyleo'
email: 'mailto:no-reply@example.com' # 原版 README 漏了
sns属性可选参数:
社交网站 | 参数 |
---|---|
微博 | weibo |
推特 | twitter |
Github | github |
知乎 | zhihu |
掘金 | juejin |
豆瓣 | douban |
简书 | jianshu |
UI中国 | uicn |
领英 | linkedin |
facebook |
|
Youtube | youtube |
instagram |
|
Dribbble | dribbble |
Behance | behance |
Medium | medium |
VK | vk |
email |
首页侧边栏和文章页面底部都会显示你的个人简介
# Author 配置博主信息
author: 'Jack'
nickname: 'xx'
bio: '程序员'
avatar: 'assets/img/avatar.jpg'
对侧边栏的标签模块进行相应配置:
# Tags
recommend-tags: true
recommend-condition-size: 12
Tags配置说明:
属性 | 参数 | 描述 |
---|---|---|
recommend-tags |
true , false |
是否显示推荐标签 |
recommend-condition-size |
12 或其他数字 |
推荐标签个数限制 |
基于Jekyll服务器生成文章索引文件 search.json
为博客提供搜索服务。输入文章标题或与文章标签相关的关键字即可。
搜索功能默认是开启的,以卡片的样式显示在侧边栏底部。如需关闭请将配置文件 _config.yml
中 search
属性的值改为 false
。
# Search
search: true
说明 | 参数 |
---|---|
开启搜索功能 | true |
关闭搜索功能 | false |
[Plus 新增:无论是否开启搜索,Plus 都会建立一个搜索页面,支持输入搜索词回车跳转 Bing 进行全文搜索。此页面默认添加至 导航栏。]
模板引入了Prism.js,一款轻量、可扩展的代码语法高亮库。
很多知名网站如MDN、css-tricks也在用它,就连 JavaScript 之父 Brendan Eich 也在个人博客上使用。
遵循 HTML5 标准,Prism 使用语义化的 <pre>
元素和 <code>
元素来标记代码区块:
<pre><code class="language-css">p { color: red }</code></pre>
在Markdown中你可以这样写:
```css
p { color: red }
```
支持语言:
- HTML
- CSS
- Sass
- JavaScript
- CoffeeScript
- Java
- C-like
- Swift
- PHP
- Go
- Python
[Plus 修改:此功能已经移除,并被自适应夜间模式替代。这个选项现在没有作用。]
晚11点至次日凌晨6点自动开启夜间模式。如果不需要,则将配置文件 _config.yml
中 nightMode
属性的值改为 false
即可。
# Night mode
nightMode: true
说明 | 参数 |
---|---|
开启夜间模式 | true |
关闭夜间模式 | false |
支持两种主题颜色蓝色(默认)和粉色
主要效果体现在首页博客封面、顶部导航栏的logo以及鼠标悬停时文字显示的颜色效果。
# theme color
theme-color: 'default' # pink or default
颜色 | 参数 |
---|---|
蓝色 | default |
粉色 | pink |
如果你希望在博客封面显示图片,需要去index.html文件中的头信息中添加 header-img
配置:
---
layout: default
home-title: Steven的博客
description: 开发者,创造者
header-img: assets/img/banner.jpg
---
在没有图片的情况下单纯显示颜色会不会太无趣了点?于是想到了加入底纹元素,底纹素材是SVG格式的(保存在css样式里),加载比图片快很多。六种底纹(电路、食物、云海、钻石等等)供你选择,配置如下:
# Hero background patterns
postPatterns: 'circuitBoard'
postPatterns
属性参数配置:
底纹描述 | 参数 |
---|---|
电路 | circuitBoard |
圆环 | overlappingCircles |
吃货日常:啃打鸡 | food |
土豪必备:钻石 | glamorous |
圈圈叉叉 | ticTacToe |
中国风:云海 | seaOfClouds |
主题开发使用的技术栈也比较简单:引入jQuery类库、使用Sass代替CSS编写样式,使用Gulp完成Sass的编译、CSS和JavaScript的代码合并压缩等任务。
如果你喜欢折腾,想对模板的代码进行修改,需要使用命令 npm install
安装 package.json
中的依赖,然后 gulp
一下即可开始你的自定义之旅。
在了解H2O主题的目录结构之前,确保你对Jekyll目录结构有所了解。
.
├── _config.yml # 配置文件
├── _includes # 页面组件方便重用
| ├── footer.html # 页脚
| └── head.html # html文档的头部内容
| └── header.html # 顶部菜单栏
| └── pageNav.html # 文章列表分页组件
├── _layouts # 布局模板
| ├── default.html # 默认模板
| └── post.html # 文章页面模板
├── _posts # 这里放文章
| ├── 2017-05-03-elements-of-javascript-style.md # 命名格式:年-月-日-文章标题.md
| └── 2007-02-21-life-on-mars.md
├── _site # Jekyll将源码处理后生成的站点文件,里面的内容可直接发布
├── assets # 存放用于线上环境的静态资源,如需修改css和js文件请到dev文件夹
| ├── css # dev文件夹中sass编译后的样式文件
| └── fonts # 字体文件
| └── icons # 图标文件
| └── img # 图片文件
| └── js # dev文件夹中处理后的脚本文件
├── dev # 开发文件
| ├── js # 存放脚本源码
| └── sass # 样式源码
| └── app.scss # 整合下面的所有样式文件
| └── base.scss # 引入字体、Reset部分样式
| └── common.scss # 模板的主要样式
| └── helper.scss # 工具样式
| └── layouts.scss # 响应式布局
└── gulpfile.js # 自动化任务脚本
└── index.html # 模板首页
└── tags.html # 标签页面
└── 404.html # 404页面
└── package.json # 管理项目的依赖项
值得注意的是,css及js的源码都在 dev
文件夹中,每一次保存 gulp 都会对它们进行处理并保存到 assets
文件夹以供 _site
上线环境使用。
Disqus是一个第三方社交评论插件,体验相当不错。
在配置文件 _config.yml
中找到comments的相关配置,设置 disqus
参数为 true
打开评论功能( false
为关闭),并且设置 disqus_url
。
# Comments
comments:
disqus: true
disqus_url: 'https://your-disqus-username.disqus.com/embed.js'
注:disqus
默认值为 false
[在 Plus 版中,Disqus 已被 Giscus 替代。请找到 giscus
设置项,并按照指示设置 giscus_script
。]
为了让文章更方便地分享,使用了第三方分享插件Share.js,支持一键分享到微博、QQ空间、QQ好友、微信、腾讯微博、豆瓣、Facebook、Twitter、Linkedin、Google+、点点等社交网站。
# Share
social-share: true # 开启或者关闭分享功能
social-share-items: ['wechat', 'weibo', 'douban','twitter']
Any types of contribution are welcome. Thanks.
接受各种形式的贡献,包括不限于提交问题与需求,修复代码。等待您的 Pull Request
Jekyll-Theme-H2O is licensed under MIT.
Jekyll-Theme-H2O-Plus is licensed under MIT.