作为标题列表,总是会有一些其他元素同时展示。例如序号、日期等等。在上节的代码示例的基础上做一些修改。
根据这个需求,我们添加一个结构
//结构
type TitleList struct {
Order string //序号
Title string //标题
DateShow string //日期
}
同时作为数据也不能是string类型了,都要改成 TitleList
//自动生成全部数据
var dataAll = []TitleList{}
...
//当前显示数据
var dataNow = []TitleList{}
dataAll = append(dataAll, strconv.Itoa(i+1)+"、"+aString)
这句写入数据的代码也要改一下
t :=TitleList{}
t.Order = strconv.Itoa(i+1)+"、"
t.Title = aString
t.DateShow = time.Now().Format("2006-01-02")
dataAll = append(dataAll,t)
这样按结构struce分别给入相应的值。作为示例,日期这里我就随意的取了当前日期时间。
剩余的,就是再改造一下模板显示数据的地方
{{range .listData}}
{{.Order}}{{.Title}}{{.DateShow}}<br>
{{end}}
把每个要显示的字段都单独调用出来。当然我这里做的比较简单直白,真实写项目的时候,就要用前端的手段美化排版一下。
通过这次的修改,代码变成了这个样子
//结构
type TitleList struct {
Order string //序号
Title string //标题
DateShow string //日期
}
//自动生成全部数据
var dataAll = []TitleList{}
func processPagesHandler(writer http.ResponseWriter, request *http.Request) {
//当前显示数据
var dataNow = []TitleList{}
//当前页码
var pageNum = 0
//每页显示记录数
var recordPerPage = 5
//自动生成全部数据
if len(dataAll)<20 {
for i := 0; i < 99; i++ {
aString := ""
rand.Seed(time.Now().UnixNano())
aNum := rand.Intn(5)+5
for j:=0; j<aNum; j++{
rand.Seed(time.Now().UnixNano())
time.Sleep(time.Nanosecond) //电脑运算太快了,短暂休眠避免随机汉字重复
aString += string(19968+rand.Int63n(40869-19968))
}
//dataAll = append(dataAll, strconv.Itoa(i+1)+"、"+aString)
t :=TitleList{}
t.Order = strconv.Itoa(i+1)+"、"
t.Title = aString
t.DateShow = time.Now().Format("2006-01-02")
dataAll = append(dataAll,t)
}
}
//获取当前页码
pageNum,err := strconv.Atoi(request.FormValue("page"))
if err != nil{
pageNum = 0
}
//获取当前显示数据
if pageNum * recordPerPage >= len(dataAll) || pageNum * recordPerPage < 0{
pageNum = 0
}
for i := 0; i < recordPerPage && (pageNum * recordPerPage + i)< len(dataAll); i++ {
dataNow = append(dataNow, dataAll[pageNum * recordPerPage + i])
}
//分页数据
var firstPage = 0
var lastPage = len(dataAll)/recordPerPage
if lastPage*recordPerPage < len(dataAll) {
lastPage++
}
var nextPage = pageNum + 1
var prePage = pageNum - 1
var page4 = map[string]int{"firstpage":firstPage,"lastpage":lastPage-1,"nextpage":nextPage, "prepage":prePage, "currentpage":pageNum+1}
var dataReturn = map[string]interface{}{"listData":dataNow,"pageData":page4}
t, _ := template.ParseFiles("./JoelTempWeb/tmplPages.html")
t.ExecuteTemplate(writer, "page", dataReturn)
}
在main里调用
http.HandleFunc("/pages/", processPagesHandler)
...
模板代码
{{define "page"}}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Go Web Programming</title>
</head>
<body>
分页啦
<hr>
{{range .listData}}
{{.Order}}{{.Title}}{{.DateShow}}<br>
{{end}}
<a href="?page={{.pageData.firstpage}}">首页</a>
<a href="?page={{.pageData.prepage}}">上页</a>
<a href="?page={{.pageData.nextpage}}">下页</a>
<a href="?page={{.pageData.lastpage}}">末页</a>
当前页:{{.pageData.currentpage}}
</body>
</html>
{{end}}
剩下的,你就去美化模板文件好了。