如何使用Jekyll在GitHub Pages上搭建网站(个人博客)

news/2024/5/17 14:48:43/文章来源:https://blog.csdn.net/qq_33919450/article/details/127859193

前言

本文很长,建议使用侧边栏进行跳转。
Jekyll 是一个基于 Ruby 语言的,用于搭建静态网站的生成器,主要用于搭建博客网站(官方自己的介绍为:Jekyll is a blog-aware, static site generator in Ruby)。但是虽然是静态网站,但是可以实现一些使用数据库的动态网站的效果和功能,是很不错的一个框架。官网为:https://jekyllrb.com。

虽然 Jekyll 官网提供了教学 《step-by-step》,GitHub 也提供了教学《About Github Pages and Jekyll》,但是二者需要交叉起来看,所以这个框架还是有点简单并且复杂的。并且有一些细节没有提到。因此,写此文来记录一下。

本文将利用 GitHub Pages 和 Jekyll 搭建一个博客网站,这也是 GitHub 推荐的搭配。搭建的博客为:https://zhonguncle.github.io。
但是本文不阐述 Jekyll 的原理,只讲步骤。 因为这样看上去简洁一点,如果你对其他相关内容可以阅读下面列出的我的其他博客:

  • 如果想查看 Jekyll 的原理、机制和结构等内容,等还请移步另外一篇博客:《Jekyll 的机制、转换步骤和结构介绍》
  • 如果想快速查看一些常用的 Jekyll 命令还请移步:《Jekyll 选项(options)和子命令(subcommand)小手册》
  • 如果想快速查看一些常用的 Jekyll 语句和结构还请移步:《Jekyll 语句语法、功能的实现方法和结构介绍小手册》

准备工作

⚠️注意:本文使用了一个没有列出的 CSS 来展示博客内容。 由于许可证限制,这里不能列出来,如果有一天我写出来自己的用于展示博客内容的 CSS,将会在此列出(应该会是 MIT License,但是不确定)。

安装Jekyll

Jekyll 安装方式非常简单,只要在终端/命令行输入以下命令即可:

gem install jekyll bundler

安装完毕之后,可以使用下面这条命令来查看安装的版本:

$ jekyll -v
jekyll 4.3.1

创建并设置GitHub pages

创建GitHub pages

安装完之后,就要创建并且设置一下 GitHub Pages 了。

创建 GitHub Pages 的方法很简单:

  1. 首先,创建一个名为用户名.github.io的 GitHub 仓库(用户名不区分大小写);
  2. 然后将这个空仓库克隆到本地。

这个时候就已经创建完毕了,可以通过https://用户名.github.io来访问了,并且可以像普通的 Git 项目一样进行处理和推送了(不过由于是空项目,所以不会显示什么,感兴趣可以自己推送一个网页看看)。

不过需要注意的是,如果后面使用/docs目录显示内容的时候,或者使用 Jekyll 操作,上传站点之后可能需要一段时间才能显示更新(官方说这个时间最长不超过一个小时)。

设置GitHub pages

接下来还要调整一下该仓库的一些设置,来方便后续的工作流程。

在该仓库的设置界面,点开“Settings”->“Pages”界面,然后在“Branch”部分选择自己想要的分支(这里是默认的main分支),然后选择/docs文件夹。这样https://用户名.github.io就会只显示/docs文件夹下的内容,而不是根文件。如下:
请添加图片描述

创建配置Jekyll的_config.yml文件

如果你是一个细心的人,会发现默认的空白仓库中是没有docs这个文件夹的。所以是需要我们手动创建的,但是 Jekyll 生成的文件夹在默认情况下是叫_site,这该怎么办呢?
如果你经常使用终端/命令行,那一定很熟悉 UNIX 命令格式命令 -选项 参数,如果你使用这种常规格式就会发现没有效果。这是因为 Jekyll 的命令并不是 UNIX 命令格式,它的参数需要去访问特定文件获得,而这个文件便是_config.yml

所以,我们在克隆到本地的空白仓库中创建一个名为_config.yml的文件(也就是仓库的根目录下),然后输入以下内容:

destination: docs

destination参数表示生成的目的文件夹名称。

更多的参数可以查看官方文档:https://jekyllrb.com/docs/configuration/options/

到这里,准备工作基本上已经完成,可以开始了。

一个简单的开始(了解工作流程)

首先来进行一个简单的开始,了解体会一下 Jekyll 的工作流程。

创建/修改文件

第一步,和所有网站一样,创建一个index.html文件(可以理解成开发的过程),内容如下:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>Home</title></head><body><h1>Hello World!</h1></body>
</html>

这是一个很简单的纯 HTML 文件,没有使用到 Jekyll 语句,但是作为理解工作流程非常有效。

生成静态网站

在开发完成之后,使用终端,在仓库目录下,输入以下命令来生成我们所需的静态网站:

jekyll build

这时候就可以发现,原本只有index.html_config.yml2个文件的文件夹中,多了一个名为docs的文件夹。点开可以发现,内容就是生成的静态网站。
如果之前没有在_config.yml文件中进行设置,那么这里生成的文件夹应该名为_site

在本地进行开发和演示

但是此时你可能会想:“我每次开发完都得重新生成一次静态网站,这样如果检查细节上的修改,不得烦死人啊!而且检查网站还得搭建一个本地服务器”

Jekyll 也考虑到这点,所以需要使用下面这条简单的命令,即可满足需求:

jekyll serve

这个命令将会在http://localhost:4000运行一个本地网络服务器,并且实时进行重新生成,而不用自己去搭建服务器和手动重新生成。

确定网站设计

在会基础的 Jekyll 工作流程之后,就需要确定博客网站需要哪些部分和内容,例如主页上显示什么,需不需要各种专栏等等内容。然后我们就针对每个功能和内容进行开发即可。

首先确定一下博客网站需要哪几种页面。思考一下发现就需要三种:主页、博客专栏页面、博客内容页面。

然后就是思考设计。作为非 UI 专业人士,这里使用 Procreate 绘制一个大概的图,明白什么意思即可。
主页设计如下:
请添加图片描述

专栏页面的设计如下:请添加图片描述

博客页面的设计如下:
请添加图片描述

接下来依次实现即可。

实现设计

在这个时候,你的项目中应该有的文件是:文件index.html_config.yml和目录docs

本章直接列出步骤,不做过多解释。如果想了解一些步骤的含义,还请移步我的另外一篇博客《Jekyll 语句语法、功能的实现方法和结构介绍小手册》。

生成导航栏

首先是导航栏部分,因为每个页面都有这个部分。

项目根目录下,新建_data目录,在里面新建一个navigation.yml文件,然后输入以下内容:

- name: 主页link: /index.html
- name: SwiftUIlink: /swiftui.html
- name: UNIXlink: /unix.html

这里表示在导航栏中创建了三个元素:主页和两个专栏 SwiftUI、UNIX,但是这三个元素连接的页面只有“主页”目前是存在的,其他两个我们后面再创建。

然后再在根目录下,新建一个_includes目录,在里面新建一个navigation.html文件,用于生产导航栏。内容如下:

<div class="header">{% for item in site.data.navigation %}<a href="{{ item.link }}" class="headerItem">{{ item.name }}</a>{% endfor %}
</div>

创建页面模板

根据之前的设计,需要设计3个页面模板:默认模板、列表页面模板和博客页面模板。

通用模板default.html是所有页面的基础,因为是所有的网页都包含的代码。内容如下:

<!doctype html>
<html><head><meta charset="utf-8"><title>{{ page.title }}</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" type="text/css" href="assets/css/headerstyle.css" /><link rel="stylesheet" type="text/css" href="assets/css/blogstyle.css" /></head><body>{% include navigation.html %}<div class="stackedit__html">{{ content }}</div></body>
</html>

博客列表界面用于显示主页和专栏,因为结构是非常相似的。内容如下:

博客页面模板article.html的内容如下:

<!doctype html>
<html><head><meta charset="utf-8"><title>{{ page.title }}</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" type="text/css" href="/assets/css/blogslist.css" /><link rel="stylesheet" type="text/css" href="/assets/css/headerstyle.css" /></head><body><div class="stackedit__html">{% include navigation.html %}<h1>{{ page.title }}</h1><div class="bloginfo"><p class="info">{{ page.date | date: "%Y-%m-%d" }} <a href="">{{page.column}}</a></p></div>{{ content }}</div></body>
</html>

实现博客分栏

如果需要详细的介绍,或者遇到下面解释不了的问题,还请移步《Jekyll 语句语法、功能的实现方法和结构介绍小手册》的相关部分。

首先需要在每篇博客的前事项(front matter)中加上category属性,如下表示属于 SwiftUI 专栏:

---
layout: article
category: SwiftUI
---

然后,在根目录创建swiftui.html文件,用于显示 SwiftUI 相关的博客。其内容如下:

---
layout: category
title: SwiftUI
info: 本专栏存放的是 Swift/SwiftUI 相关内容的笔记、问题及其解决方案
---{% for blog in site.blogs %}{% if blog.category == "SwiftUI" %}<li><h2><a class="blog" href="{{ blog.url }}">{{ blog.title }}</a></h2><p class="info">{{ blog.date | date: "%Y-%m-%d" }}</p>{{ blog.excerpt }}</li>{% endif %}
{% endfor %}

info属性就是专栏简介。

然后继续在根目录下创建unix.html文件,用于显示 UNIX 相关的博客。内容如下(与上面相似):

---
layout: category
title: UNIX
info: UNIX 相关的内容就在该专栏,包括但不限于 Linux 各种发行版(包括 WSL)、macOS、bash、原理等 UNIX 相关的内容。需要注意的是,虽然软件的使用教程以及排错方法也在该专栏,但是还是请查看专栏《软件/程序教程》,一些小问题可以查看专栏《非硬件小问题》。
---{% for blog in site.blogs %}{% if blog.category == "UNIX" %}<li><h2><a href="{{ blog.url }}">{{ blog.title }}</a></h2><p class="info">{{ blog.date | date: "%Y-%m-%d" }}</p>{{ blog.excerpt }}</li>{% endif %}
{% endfor %}

这时候就实现了分栏。运行一下jekyll server访问http://127.0.0.1:4000看看效果。如下:
请添加图片描述

博客页面

博客页面不用特别操作,只要按照上文设置了博客页面模板,并且放置在指定的位置,那么就会根据模板自动生成页面,如下:
请添加图片描述

修改主页

之前创建的index.html需要修改一下,把内容修改成如下内容:

---
layout: default
title: ZhongUncle 的博客主页
---
<h1>一些介绍</h1>
<p>我是 ZhongUncle,欢迎来到我的博客。本站点主要用于备份我发在 CSDN 上的博客,以及一些有趣尝试的纪录</p><h1>最新</h1><ul>{% for blog in site.blogs %}<li><h2><a href="{{ blog.url }}">{{ blog.title }}</a></h2>{{ blog.excerpt }}</li>{% endfor %}
</ul>

效果如下:
请添加图片描述

好啦,这样自己的博客网站就搭建好啦,也很容易更新。

希望能帮到有需要的人~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_782092.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用WebDeployment Project改善VS2005发布网站问题 (三) 常见问题

一、发布后网站浏览时出现乱码(http://www.cnblogs.com/chy710)如果页面编码是gb2312&#xff0c;可能会有此问题&#xff0c;请使用utf-8编码&#xff0c;vs2005中打开页面切换到HTML视图&#xff0c;选择[文件] / [高级保存选项],选择utf-8,保存&#xff0c;OK。二、发现不明…

web 2.0 网站推荐

web 2.0是一个很热的话题&#xff0c;作为一条小网虫&#xff0c;自然也会凑凑这个热闹。当然了&#xff0c;网上讲述web 2.0的文章可谓铺天盖地了&#xff0c;看了那么多&#xff0c;看了那么久&#xff0c;我也没有看出个所以然来。总之&#xff0c;所谓2.0就是1.0的升级版呗…

png图标搜索网站

推荐一个png图标搜索网站&#xff1a; http://www.iconpng.com/ 能找到很多好东东&#xff0c;设计网站的时候帮了我不少忙

安装好IIS后发布网站

首先&#xff0c;进行网站发布是需要IIS支持的&#xff0c;此处默认已经安装好IIS&#xff0c;并进行了Asp.net注册过程&#xff08;此步骤必需 &#xff0c;因为我是先安装的 .net 环境 &#xff0c;再安装的IIS&#xff09;。 其次&#xff0c;以下步骤可以方便指导新手如何…

一些免费的WebService的服务网站(转发)

免费&#xff1a;网站首页 http://www.webxml.com.cn/zh_cn/web_services.aspx 例如&#xff1a; [新] 中文<->英文双向翻译WEB服务 获得标准数据Endpoint: http://fy.webxml.com.cn/webservices/EnglishChinese.asmx Disco: http://fy.webxml.com.cn/webservices/En…

为了打击网站被黑作弊行为,360搜索上线悟空算法2.0

我们在搜索浏览网页的时候&#xff0c;经常会出现正常网页跳转至含有色情&#xff0c;博彩等信息的恶意站点上去。这样严重影响到了用户的搜索体验&#xff0c;为了打击此类行为&#xff0c;360搜索正式上线了&#xff1a;“悟空算法2.0”网站被黑是一种较为常见的现象&#xf…

html搜索迎,老网站的域名来新建网站(保留原站内容与链接)

我们维护了一段时间网站&#xff0c;发现这个网站不是我们想要的那个样子&#xff0c;如果选择直接不要原来的内容&#xff0c;一来感觉可惜了&#xff0c;二来是不利于搜索引擎优化。今天&#xff0c;错误博客( cuowu.com )带来的是《网站的域名来新建网站(保留原站内容与链接…

极域电子教室软件怎么脱离控制_企业官网推广seo排名优化的优势?seo排名方法怎么样?...

seo排名影响的因素有很多&#xff0c;在做排名优化的时候&#xff0c;我们需要对相关的排名方法进行充分的了解&#xff0c;比如seo排名优化的优势有哪些?seo排名方法怎么样?下面就跟宝丞网小编一起来了解seo排名优化的优势。seo排名优化的优势seo排名优化的优势1.节省费用&a…

服务器网站打开慢跟什么有关系吗,服务器网站打开慢是什么原因 | 帮助信息-动天数据...

服务器网站打开慢是什么原因作者&#xff1a;dthost |时间&#xff1a;2018-01-02 |5,709 次阅读笔者是销售虚拟主机的&#xff0c;不管是买空间的&#xff0c;还是没有卖空间的&#xff0c;都会经常遇见反应网站慢&#xff0c;或者服务器慢的情况&#xff0c;我们下面把我们自…

java网站优化_什么是java 网站性能优化?

信息技术的发展&#xff0c;各种软件的研发&#xff0c;给我们生活带来了许多方便和乐趣。不同的软件都是不同编程语言做的&#xff0c;java也是众多编程语言的一种&#xff0c;想做好一个好的java软件&#xff0c;java 网站性能优化你应该了解。一、什么是java语言Java是一门面…

asp.net mvc2网站部署在IIS6的方法

部署环境&#xff1a; Server 2003 IIS6 1.先安装好IIS6&#xff0c;再安装.net framework 4.0和asp.net mvc 安装包(主要是里面的一个dll&#xff0c;不安装也可以&#xff0c;只需要找到这个dll&#xff0c;将mvc.dll 放入网站bin目录下&#xff0c;这个dll文件的默认路径是C…

删除 Windows Azure 网站上的标准服务器头

编辑人员注释&#xff1a; 本文章由 Windows Azure 网站团队的项目经理 Erez Benari 撰写。 请求和响应中包含的 HTTP 头是Web 服务器和浏览器之间的 HTTP 通信过程的一部分。例如&#xff0c;以下是一个典型网站上某个 Web 请求的典型响应中记录的头&#xff1a; HTTP 头是客户…

第二章:SE简单对话 【闲话家常---《SEO通俗入门精谱》】

在上一章中&#xff0c;我们谈到了当前的搜索引擎的具体工作原理&#xff0c;本章将接着上面的内容而来&#xff0c;为大家进一步阐述SE的分类&#xff0c;以及SE的未来发展方向等两方面的内容&#xff0c;以期让大家更加明确的知道SE到底是干什么的&#xff0c;以及SE在发展过…

nginx服务器实现网站的301跳转

网站不带3W的域名在访问时自动跳转到带3w的域名&#xff0c;这是做网站seo最基本的要求。nginx服务器如何做301跳转呢&#xff1f; 1.进入vhost目录&#xff1a; /usr/local/nginx/conf/vhost 这里存放的是网站的配置文件&#xff0c;找到您相应的配置文件&#xff0c;使用vi打…

如何进行网站流量分析(一)

如何进行网站流量分析&#xff08;一&#xff09; 流量分析整体来说是一个内涵非常丰富的体系&#xff0c;整体过程是一个金字塔结构&#xff1a; 金字塔的顶部是网站的目标&#xff1a;投资回报率&#xff08;ROI&#xff09;。 网站流量分析模型举例 1 网站流量质量分析&a…

如何进行网站流量分析(二)

如何进行网站流量分析&#xff08;二&#xff09; 流量分析常见分类 指标是网站分析的基础&#xff0c;用来记录和衡量访问者在网站自的各种行为。比如我们经常说的流量就是一个网站指标&#xff0c;它是用来衡量网站获得的访问量。在进行流量分析之前&#xff0c;我们先来了…

网站流量日志分析流程及架构

网站流量日志分析流程及架构 1. 数据处理流程 网站流量日志数据分析是一个纯粹的数据分析项目&#xff0c;其整体流程基本上就是依据数据的处理流程进行。有以下几个大的步骤 &#xff1a; 数据采集 数据采集概念&#xff0c;目前行业会有两种解释&#xff1a;一是数据从无…

让你的网站快速被蜘蛛抓取收录的方法

据真实调查数据显示&#xff0c;90%的网民会利用搜索引擎服务查找需要的信息&#xff0c;而这之中有近70%的搜索者会直接在搜索结果的自然排名的第一页查找自己所需要的信息。由此可见&#xff0c;目前来讲SEO对于企业和产品&#xff0c;有着难以替代的重要意义。 关于网站让引…

借助微信SEO也可以轻松引流快速增粉

最近有些人莫名其妙地加了我。后来问他们是通过微信搜索&#xff0c;搜到我的文章&#xff0c;然后看到联系方式加我的。 从那以后&#xff0c;我就开始研究微信搜索&#xff0c;今天跟你分享新媒体引流其中一个核心的引流渠道“微信SEO”。 目前做微信公众号涨粉比较难了&…

网站转换APP源代码 WebAPP源代码 网站生成APP源代码 Flutter项目 带控制端

网站转换APP源代码 WebAPP源代码 网站生成APP源代码 Flutter项目 带控制端 网站转换成APP的源代码,开发语言使用Flutter,开发工具使用的是AndroidStudio,你只需要在APP源代码里面填写你的域名,即可生成即可生成APP,包括安卓或者苹果,与此同时有APP的控制端.你可以通过控制端设…