通过这个脚手架,你可以快速建立一个如同 Kun's Blog 的博客系統。
- GatsbyJS v3,更加快速
- 支持 Google Analytics
- Web App Manifest
- Netlify 网站构建和访问优化
- 基于 Gitalk 的评论系统 (powered by Gitalk)
- 高速解析 Markdown (基于gatsby-transformer-remark)
- 良好的 seo
- 一键切换日间夜间模式
- 支持 Chrome APP
- 支持 ts
- 支持 Notion (roadMap)
- 支持站内搜索 (roadMap)
- 分页
- 支持不同分类(目录、时间、标签)
- 响应式 Css
- 使用 Font Awesome (基于 react-fontawesome)
- 流畅滑动设计 (基于 smooth-scroll)
- 整体风格与 Hexo Icarus 主题近似,支持无缝迁移
你可以直接修改 /src/content/*.md
,或者接入 Netlify-cms cms 系统来管理,也可以等待后续支持 Notion 更为方便。
你可以基于本博客代码进行以下优化:
- 代码优化
- 使用 SCSS 添加更多样式
你可以使用以下按钮快速构建一个副本:
在你点击上面的按钮之后,Netlify 会取得你的 Github 授权,以及选择仓库名称。Netlify 会自动创建一个仓库,并且复制那里的文件。
然后 Netlify 会自动构建和部署一个新的网站,就是一个完整的博客系统
如果你喜欢 我的博客,请 star 本仓库,多谢。
- Git
- Node:建议 12.0.0 或更高版本
- fork 本项目(想要修改代码提 pr)
- 安裝 Gatsby-CLI
npm install --global gatsby-cli
- 使用 Gatsby 启动器创建新的 Gatsby 項目,
awesome-blog
是您博客的文件夾
gatsby new awesome-blog https://github.com/Kun8018/gatsby-starter-icarus-blog
## 使用ssh
gatsby new test-blog [email protected]:Kun8018/gatsby-starter-icarus-blog
- 打开文件夹
cd awesome-blog
-
运行代码
npm start
启动热重载服务 (基于Gatsby)open http://localhost:8000
在浏览器中打开
在 data/config
编辑 exports
注意: 想要查找 theme_color 十六进制代码,请单击此处。
module.exports = {
title: 'your blog title here',
maxPages: 12
meta: {
description: 'blog description',
keyword: 'blog, JavaScript',
theme_color: '#hexcode',
favicon: 'https:yourimageurl.com',
google_site_verification: 'your google verification hash',
},
name: 'your name',
email: '[email protected]',
iconUrl: 'https://youricon.jpg',
License: 'by',
url: 'https://yourblog.me',
about: '/2018/05/01/about-your-name/',
// Sidebar
zhihuUsername: 'your zhiu user name here',
githubUsername: 'your github user name here',
friends: [
{
title: 'friend title',
href: 'link to their blog',
}
]
插件的配置文件:
gaOptimizeId: 'GTM-WHP7SC5',
gaTrackId: 'UA-84737574-3',
navbarList: [
{
href: '/stats/',
title: 'stat title',
},
{
href: '/tags/',
title: 'tags',
},
{
href: '/guestbook/',
title: 'guestbook',
},
{
href: '/blog/',
title: 'your title',
},
],
redirectors: [
{
fromPath: '/',
toPath: '/page/1',
},
],
配置Gitalk
gitalk: {
clientID: '',
clientSecret: '',
repo: 'Kun8018.github.io',
owner: 'Kun8018',
admin: ['Kun8018'],
distractionFreeMode: true,
},
}
Kun 的博客 目前正在使用Netlify,也可以使用 Github Pages 直接部署。
-
Github Pages
npm run deploy
将博客部署到 Github Pages -
Netlify
自动部署
-
对于
window is defined
, 引包前检查 window :if (typeof window !== `undefined`) { const module = require("module"); }
-
npm run reset
清除本地缓存
请阅读 CONTRIBUTING.md 获取更多信息。
如果您对此项目感兴趣,请联系Kun Zhang。
感謝关注本 Repo...... :)