Go Web API分页核心是解析URL的page和limit参数并内存切片:page默认1且≥1,limit默认10且上限100;起始索引为(page-1)*limit,结束索引取min(start+limit,数据长度);返回含Data、Page、Limit、Total、TotalPages的PaginatedResponse。

用 Go 实现 Web API 分页,核心是解析 URL 中的 page 和 limit 查询参数,再对数据做切片(slice)处理。不依赖 ORM 或数据库分页时,内存中切片是最直接的方式,适合中小数据量或原型开发。
解析 Query 参数:page 和 limit
从 HTTP 请求中提取分页参数,需做类型转换和默认值处理。避免 panic,要校验数值合理性。
- page 默认为 1,必须 ≥ 1;小于 1 则设为 1
- limit 默认为 10,建议设上限(如 100),防恶意请求拉取全量数据
- 用
strconv.Atoi转换,失败时使用默认值
示例代码:
page, _ := strconv.Atoi(r.URL.Query().Get("page"))
if page < 1 {
page = 1
}
limit, _ := strconv.Atoi(r.URL.Query().Get("limit"))
if limit < 1 || limit > 100 {
limit = 10
}计算切片起止索引
Go 切片是左闭右开区间 [start:end],所以:
立即学习“go语言免费学习笔记(深入)”;
- 起始索引:
start := (page - 1) * limit - 结束索引:
end := start + limit - 需确保
end不超过原始数据长度,否则会 panic
安全切片写法:
start := (page - 1) * limit
if start >= len(data) {
data = []Item{} // 页码超出范围,返回空切片
} else {
end := start + limit
if end > len(data) {
end = len(data)
}
data = data[start:end]
}返回分页元信息(可选但推荐)
客户端常需知道总页数、当前页、总数等,方便渲染分页控件。可封装成结构体返回:
type PaginatedResponse struct {
Data []Item `json:"data"`
Page int `json:"page"`
Limit int `json:"limit"`
Total int `json:"total"`
TotalPages int `json:"total_pages"`
}计算 TotalPages:用 (total + limit - 1) / limit 实现向上取整。
完整 handler 示例(基于 net/http)
整合以上逻辑,一个简洁可用的分页接口:
func listItemsHandler(w http.ResponseWriter, r *http.Request) {
// 假设 items 是你的原始数据(例如从内存/JSON/轻量 DB 获取)
items := getItems() // []Item
page, _ := strconv.Atoi(r.URL.Query().Get("page"))
if page < 1 { page = 1 }
limit, _ := strconv.Atoi(r.URL.Query().Get("limit"))
if limit < 1 || limit > 100 { limit = 10 }
start := (page - 1) * limit
total := len(items)
var paged []Item
if start < total {
end := start + limit
if end > total {
end = total
}
paged = items[start:end]
}
totalPages := (total + limit - 1) / limit
json.NewEncoder(w).Encode(PaginatedResponse{
Data: paged,
Page: page,
Limit: limit,
Total: total,
TotalPages: totalPages,
})}
基本上就这些。Query 分页 + 切片简单直接,适合起步;数据量大时建议切换到数据库 LIMIT/OFFSET 或游标分页。










