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语言免费学习笔记(深入)”;
我的博客
ain>
{{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 编译成单二进制,方便分发和部署。
基本上就这些,不复杂但容易忽略细节。
以上就是如何做一个Golang静态博客生成器_Golang模板渲染与自动化构建流程的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1428557.html
微信扫一扫
支付宝扫一扫