为什么我选择用 Github issues 来写博客

2019-05-22 20:43:28 +08:00
 jrainlau

对于爱写东西的人来说,挑一个合适的博客平台是非常重要的。而作为一个 Web 开发者,我们肯定都希望能够拥有一个高度定制化的博客平台,用以展示我们独一无二的个性以及记录长久以来的学习工作等。与此同时,我们也希望这个平台可以让我们方便地发布内容,提供完整的点赞、留言等操作。在经历过 Hexo,Wordpress,自行搭建服务等一系列尝试以后,我最后选择了以 Github issues 来作为我的博客平台。

博客的基本能力

对于一个合格的博客平台来说,它主要提供了下列几种能力:

  1. 个人介绍 对于个人博客来说,它首先要支持展示博主的个人介绍。这个个人介绍里面可能包括了头像、昵称、联系方式等基本内容,能够让读者能够对这个博客的主人有一个基本的认识。

  2. 文章的撰写与展示 对一个博客来说,最重要的就是它的内容,也就是里面的文章。一个好用的博客平台应该具备方便的撰写文章的能力,让够让用户毫无负担地撰写、编辑自己的文章。此外,还必须能够文章的信息,比如展示标题、节选、封面,创建 /修改时间,评论点赞数等等。

  3. 归档能力 一篇文章的撰写时间、内容标签 /分类等都是不同的,如何按照不同的要求对这些文章进行归档整理,也是考验博客平台的能力之一。再者,当文章数量较多的时候,添加一个搜索的功能也能大大方便读者对博客的浏览。

  4. 博主与读者互动的能力 仅仅只有博主一个人自嗨可能难以激发写作的动力,如果博客能够提供博主与读者互动的能力,将能有效激励博主持续创作,更能提升文章的传播度——点赞和评论功能则是互动能力中最重要的功能之一。

经过上面的几个点,基本可以知道一个博客平台,其主要功能就是“展示自己,沟通外界”。在满足这个基础的前提下,它也应该具备方便操作,高度定制化的特点。

为什么不选择其他方案

在文章的开头我有提到,我曾经尝试过用 Wordpress,Hexo,自行搭建服务等途径去尝试维护博客。但这些尝试的结果均不合我意,最后无疾而终。归根结底,就是不够自由和方便。

举个例子,Wordpress 和 Hexo 都具备搭建一个主题漂亮、功能齐全的博客的能力,但是这些都必须要在它们所制定的规则下进行。如果我想 DIY 一个主题,或者加入任何我想要的新能力,都必须仔细翻阅它们的文档,找到对应的规则再尝试去实现,可谓是戴着镣铐跳舞。除此之外,要发布新的文章,动辄就要在本地跑命令行,实在是非常不优雅。更有甚者,如果希望为文章添加评论功能,还要费一大番周折,想必体验过的人都懂。

至于自行搭建服务,可谓是既自由又方便,想要任何功能都可以自己实现。但这种方案最大的缺点是成本较高。对于人力成本来说,服务器数据库配置、域名、备案等一系列操作非常烦人,甚至还要考虑告警、负载、宕机等一堆的运维问题。折腾多了,也没什么心思往里面写文章。对于金钱成本来说,买域名,买服务器也是一笔花销,尤其是当我们某段时间文章产出特别少的时候,总觉得白养了一台服务器……

选择 Github issues

首先是 Github,然后才是 issues。

作为全球最大的代码托管平台,又刚刚被微软收入麾下,其可靠程度是非常高的,基本不用担心存放在里面的数据会丢失(想想看国内说没就没的网易博客,百度贴吧等)。

在 Github 上我们可以精心编辑自己的账户信息,包括头像、昵称、邮箱、工作单位等等。

Github issues 提供了非常方便快捷的编辑能力,尤其是贴图。它支持通过拖拽、粘贴、选择的方式上传图片,图片会存放在 https://user-images.githubusercontent.com 这个地方,且支持外链——这也意味着我们可以很方便地把 issue 的内容转载到其他的平台。

在 Github issues 里面,可以为某条 issue 添加点赞、爱心等互动标签( Reactions ),也可以设置分类标签( Labels ),更可以给 issue 添加评论( Comment )。

最为重要的是 Github 提供了一套满足了绝大部分需求的 API,囊括了 REST 和 GraphQL 的调用方式,这才是 Github 能够成为我们博客平台的大杀器,这个接下来会详细说明。

不难看出,Github issues 拥有着前文提及的一个博客平台所应具备的各种能力。接下来我们将以 Github issues 作为博客平台的管理后端,以 API 来实现和客户端的数据交互。

天生的前后端分离

关于 Github API 的授权和调试,可以查阅我的另一篇文章《基于 Github API 的图床 Chrome 插件开发全纪录》

我们使用 Github issues 作为博客平台,也就是相当于管理后端。我们在管理后端里面撰写文章,设置标签,回复评论,然后通过 API 调用把数据传送给客户端。

几个比较常用的 v3 API 如下:

当然你也可以使用 v4 的 GraphQL 接口,也是非常的方便,感兴趣的可以自行研究。

管理后端直接用现成的 Github issues 页面,那么客户端则使用 Github 为开发者免费提供的静态页面部署服务 Github pages。要使用这个服务,只需要开通一个仓库,然后在仓库的 Settings 里面找到 Github pages 并打开即可,默认会以 Master 分支的根目录作为静态资源目录,我们只需要把客户端的静态资源直接放置在这里就好。

开通了 Github pages 以后,便可以通过其提供的 URL 直接在浏览器里访问到博客了,而博客的数据则完全加载自 Github API。

通过已授权的接口,还允许提交评论等功能:

结语

总结一下,Github issues 提供了一个博客平台所需的的各项基本能力,与 Github 的可靠性,API 的全面性,Github pages 的便捷性结合在一起,都非常适合作为一个博客平台来使用。我基于 Github issues 的个人博客也已经上线,欢迎前来体验:

https://jrainlau.github.io/#/

如果你也觉得不错的话,赶快给自己也搭一个基于 Github issues 的博客吧,期待与你的交流!

8048 次点击
所在节点    程序员
50 条回复
loading
2019-05-22 20:54:14 +08:00
我的也是用 gayhub issues 的,用的 mirror
http://sync.sh

话说好久没写了……
kingcos
2019-05-22 20:57:03 +08:00
我本来直接用的 Issues,还做了个小程序…后来还是换成了 Hugo😂

丢站跑…

https://maimieng.com/
acehow
2019-05-22 21:08:28 +08:00
我选择不写博客
LeonKennedy
2019-05-22 21:42:07 +08:00
您哪位
Fazauw
2019-05-22 21:47:55 +08:00
不错,再配个域名,当真是不错(这样算不算滥用 GitHub ?)
junjieyuanxiling
2019-05-22 21:54:23 +08:00
用 issue 写博客,你就不怕 GitHub 反滥用送你的博文上天?
able
2019-05-22 21:56:20 +08:00
我用 weibo
vincentnifang
2019-05-22 21:57:14 +08:00
“。。。又刚刚被微软收入麾下。。。”,让我想到了 msn space,你甚至可以在主页面里面插入自己个性化的 html。学生时期花了好多心思,可惜最后挂了。。。
CEBBCAT
2019-05-22 22:00:09 +08:00
@LeonKennedy #4 太没品了,哈哈哈
loading
2019-05-22 22:01:04 +08:00
@junjieyuanxiling 请研读一下 github 的相关文档再说这事。
CEBBCAT
2019-05-22 22:03:07 +08:00
总结部分怎么说呢……虎头蛇尾吧,要是能总结好就不用去看正文了。
ysc3839
2019-05-22 22:09:15 +08:00
选择 WordPress 和 Hexo 是为了避免重复造轮子吧?选择现成的那自然会有所限制,因为这像是在别人的地基上建房。
但是用 GitHub issue 写博客的话还得自己开发一套网站系统,对于有时间精力能力的人来说问题不大,但对于没有这些条件的人就很麻烦了。这可能也是很多人选择 CSDN 等博客网站的原因,他们可能并不研究前后端开发。
azuki
2019-05-22 22:30:56 +08:00
支持 rss 吗,别人要怎么知道你发了新博文呢
notreami
2019-05-22 22:44:06 +08:00
为什么我选择用 Github issues 来写博客
为什么我选择用 Github issues 来写博客
为什么我选择用 Github issues 来写博客
Weixiao0725
2019-05-22 23:46:46 +08:00
有个问题是,这种页面不好写数据公式吧?

其实可以用 jupyter 写,然后传到 GitHub 上,好像 GitHub 自动可以解析 .ipynb 的文件,
也可以用 https://nbviewer.jupyter.org/ 进行展示。
Akkuman
2019-05-23 00:08:40 +08:00
收录是问题
hanxiV2EX
2019-05-23 00:33:05 +08:00
我也是用的 issues 写的,但是没啥可写的。https://blog.hanxi.info
janus77
2019-05-23 00:53:27 +08:00
以前用了一段时间,总感觉怪怪的… issue 开放,等于编辑后台公开了,总是怕别人对你的内容做什么改动,或者不习惯后台被人看到。
另外提新 issue 也是自由的,可能会有不是作者创建的文章。
再有就是主题和插件的丰富度了
dobelee
2019-05-23 01:43:58 +08:00
如楼上,出了个争议话题,你的 issues 就炸了。😏
lulinux
2019-05-23 02:55:10 +08:00
对于这些国外空间,打开速度是个硬伤。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/566714

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX