热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

创造属于自己的静态博客

可以前往我的博客阅读:https:ssshooter.com2019-020前言本文并不是从0开始使用gatsby.js搭建博客,starter使

可以前往我的博客阅读:https://ssshooter.com/2019-02...

0 前言

本文并不是从 0 开始使用 gatsby.js 搭建博客,starter 使用的是 gatsby-starter-blog。使用 gatsby-starter-blog 可以大量节省项目搭建时间,直接得到一个最简单的博客模版,这个模板的缺点是功能少,但是反过来说优点是有较高的自由度。

根据下面整个流程做好的静态博客大概长这个样:https://ssshooter.com/tag/gatsby

我从最简单的博客模板开始添加功能的原因,就是可以让自己更熟悉整个博客的构造,自己可以随心所欲地添加功能,这才是真正的自己的博客。以前用过 Wordpress 和 Hexo,可能就是因为下载下来模版就太完善了,根本不想自己研究里面的实现,然后模板不加修改样式就与其他人一摸一样,变得很没特色,所以我也失去的更新的欲望。所以自己定值博客,或许可以让自己坚持更新下去。

整个流程最主要是前面 5 步,后面的 3 步都是非必要的,其他附加功能后续可能还会有更新。这篇文章的作用是一个导航,下面只会简单概括文章内容,详细内容请点全文链接。你可以根据你的需要一步一步进行,也可以跳过熟悉的步骤。

前置知识

  • Javascript
  • React
  • graphQL(次要,即时上手也基本能看懂)

优势

  • 因为提前生成为静态文件、不涉及到数据库,所以静态相对安全、稳定、高速
  • 无后端服务,无后端相关经验也能做好(如果不做下面的语雀推送的话)
  • 搜索引擎易抓取,搜索功能可以直接借用搜索引擎(搜索时添加 site:)
  • 涉及到的知识点比较广,对开发人员开放眼界也是极好的
PS. 本教程涉及到的服务都是免费的,穷苦学生党莫慌(不过域名还是没有免费的)

1 关键文件

全文链接

这一部分主要介绍模板的下载、项目结构及其一些关键文件。主要会提到 gatsby-node.js(页面生成函数所在文件)、/src/templates/blog-post.js(生成页面所用模板)以及 gatsby-config.js(Gatsby 的配置文件)。

2 实现分页

全文链接

现成模板缺少博客最重要的功能——分页。因为分页实现十分重要,并且可以借此理解页面生成原理,所以用自己实现分页来入门 Gatsby 我觉得是个不错的选择。

实现的关键在于模板文件的修改graphQL 查询的编写。(本项目所需的 graphQL 要求不高,但是对此感兴趣的话可以深入了解一下这个查询语言,中文文档在此)

3 样式调整

全文链接

比较简单的一节,包括修复代码高亮覆盖主题样式两部分。注意一下使用全局 CSS 的 bug 就 OK 了。

4 标签系统

全文链接

标签系统实现了标签汇总页和各个标签的文章列表页,是 graphQL 查询实践的加强版,原理跟分页是一样的,不过复杂一点看起来有一丁点望而生畏。

5 博客上线

全文链接

网站上线的步骤,包括把项目部署到 netlify 和自定义域名设置相关问题与解释。

6 评论系统

全文链接

首先是因为几个出色的社会化评论服务网站都已经被墙了,然后是自己有一点对数据的占有欲,所以这一节甚至要自己搞一个评论系统。不过借助现成的 staticman,这一步也不会太麻烦。

7 文章目录

全文链接

良好的文章页面必不可少地需要一个文章导航,对不起!由于难度的误判,这个功能虽然来晚了,但是绝对不会缺席!使用 gatsby-transformer-remark 轻松解决问题~

EX 使用语雀发布到博客

全文链接

前置知识点:使用 Github API 更新仓库

比较好玩的一节,主要好玩在使用 GitHub 接口提交文件,感觉打开了新世界的大门。配合上语雀的文章发布推送绝配,于是有了这么个功能专题。

「我很懒,果然还是不想自己动手」

「我认真看完了,都看懂了,但是真的没时间做呀」

好吧...那我还是提供一个拿来即用的渠道吧?我看网上也有很多 clone 即用的博客,但是总觉得有点违背我写这个教程的初心?。所以我至少希望大家是看完文章再 clone,这么做起码还是有能力「自定义」你的博客。

以下是 clone 即用的方法:

clone 此仓库 -> https://github.com/ssshooter/...

clone 后的默认样式是这样的,也是比较简单的,功能相较于官方的 starter 加入了上述的:分页功能和标签功能,并且提供了一个简单的图库,但是评论系统(代码没有删除只是注释了)和语雀发布系统当然是没有接通的,需要的话请手动实现~

配置后部署到 netlify 即可,更新文章时在 /src/pages/ 文件夹添加文章然后推送到 GitHub 就会直接更新。

未来

本系列依然会继续更新,UI 肯定会继续调整,功能肯定会增加。想要坚持写 blog,要先喜欢自己的 blog,用心添加新功能吧!



推荐阅读
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • Java学习笔记之使用反射+泛型构建通用DAO
    本文介绍了使用反射和泛型构建通用DAO的方法,通过减少代码冗余度来提高开发效率。通过示例说明了如何使用反射和泛型来实现对不同表的相同操作,从而避免重复编写相似的代码。该方法可以在Java学习中起到较大的帮助作用。 ... [详细]
  • 本文详细介绍了在Centos7上部署安装zabbix5.0的步骤和注意事项,包括准备工作、获取所需的yum源、关闭防火墙和SELINUX等。提供了一步一步的操作指南,帮助读者顺利完成安装过程。 ... [详细]
  • 大坑|左上角_pycharm连接服务器同步写代码(图文详细过程)
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了pycharm连接服务器同步写代码(图文详细过程)相关的知识,希望对你有一定的参考价值。pycharm连接服务 ... [详细]
  • 一、Struts2是一个基于MVC设计模式的Web应用框架在MVC设计模式中,Struts2作为控制器(Controller)来建立模型与视图的数据交互。Struts2优点1、实现 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 本文介绍了使用postman进行接口测试的方法,以测试用户管理模块为例。首先需要下载并安装postman,然后创建基本的请求并填写用户名密码进行登录测试。接下来可以进行用户查询和新增的测试。在新增时,可以进行异常测试,包括用户名超长和输入特殊字符的情况。通过测试发现后台没有对参数长度和特殊字符进行检查和过滤。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 现在比较流行使用静态网站生成器来搭建网站,博客产品着陆页微信转发页面等。但每次都需要对服务器进行配置,也是一个重复但繁琐的工作。使用DockerWeb,只需5分钟就能搭建一个基于D ... [详细]
  • 生产环境下JVM调优参数的设置实例
     正文前先来一波福利推荐: 福利一:百万年薪架构师视频,该视频可以学到很多东西,是本人花钱买的VIP课程,学习消化了一年,为了支持一下女朋友公众号也方便大家学习,共享给大家。福利二 ... [详细]
author-avatar
诸葛二蛋
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有