Golang静态博客生成器核心是模板渲染与自动化构建,使用html/template处理页面结构,goldmark解析Markdown,通过CLI一键生成静态文件。

做 Golang 静态博客生成器,核心是模板渲染和自动化构建。用 Go 的 html/template 包处理页面结构,结合文件读写与目录遍历实现内容生成。整个流程可以完全由一个简单的 CLI 工具控制,无需依赖外部框架。
模板设计与渲染逻辑
Go 的模板系统强大且安全,适合生成 HTML 页面。你需要定义基础布局和内容模板。
在项目中创建 templates/ 目录,放入以下文件:
- layout.html:页面骨架,包含 header、footer 和 content 占位
- post.html:文章页模板,嵌入到 layout 中
- index.html:首页,列出所有文章标题与摘要
示例 layout.html:
立即学习“go语言免费学习笔记(深入)”;
我的博客
{{template "content" .}}
post.html 只需定义 content 模板区块:
{{define "content"}}{{.Title}}
{{end}}
在代码中解析并组合模板:
tmpl := template.Must(template.ParseGlob("templates/*.html"))渲染时传入数据结构即可生成完整 HTML。
内容解析与数据建模
文章通常用 Markdown 存储。创建 posts/ 目录存放 .md 文件,每篇包含元信息(如标题、日期)和正文。
定义结构体表示文章:
type Post struct {Title string
Date string
Slug string
Body template.HTML
}
使用 github.com/yuin/goldmark 将 Markdown 转为 HTML:
var md = goldmark.New()func renderMarkdown(text string) template.HTML {
var buf bytes.Buffer
if err := md.Convert([]byte(text), &buf); err != nil {
panic(err)
}
return template.HTML(buf.String())
}
读取文件时,提取文件名作为 slug,首几行可模拟 front matter 解析元信息,剩余部分转为 HTML。
自动化构建流程
编写 main 函数实现一键生成:
- 遍历 posts/ 目录,读取所有 .md 文件
- 逐个解析内容,生成 Post 实例
- 按模板渲染单篇文章,输出到 public/posts/
- 整理文章列表,渲染首页到 public/index.html
添加 os.RemoveAll("public") 与 os.Mkdir 确保输出目录干净。
运行 go run main.go 即可生成全站静态文件。可进一步封装为 make build 命令。
配合 GitHub Actions,推送到仓库时自动部署到 Pages 或 CDN。
扩展建议
后续可加入 RSS 生成、标签分类、分页功能。甚至支持热重载:用 fsnotify 监视文件变化,自动重建。
静态博客不追求复杂,重点是清晰结构与可靠输出。Go 编译成单二进制,方便分发和部署。
基本上就这些,不复杂但容易忽略细节。










