我正在开发golang网络应用。在那里,我需要迭代HTML行n
次。
func index(w http.ResponseWriter, r *http.Request) {
tmpl := template.Must(template.ParseFiles("templates/index.html"))
n := 5
tmpl.Execute(w, n)
}
<ul>
<li><a href="/?page=1">1</a></li>
<li><a href="/?page=2">2</a></li>
.
.
.
<li><a href="/?page=n">n</a></li>
</ul>
我该如何实现?
答案 0 :(得分:8)
要在Go模板中重复某些内容,您可以使用{{range}}
操作。但是{{range}}
操作需要它可以迭代的内容,例如切片,数组或地图。
所以你必须喂它。但是,不需要记忆的空切片就足够了,例如, make([]struct{}, n)
。
模板代码:
const templ = `<ul>
{{range $idx, $e := .}}
<li><a href="/?page={{$idx}}">{{$idx}}</a></li>
{{end}}
</ul>`
测试它:
tmpl := template.Must(template.New("").Parse(templ))
n := 5
if err := tmpl.Execute(os.Stdout, make([]struct{}, n)); err != nil {
panic(err)
}
输出(在Go Playground上尝试):
<ul>
<li><a href="/?page=0">0</a></li>
<li><a href="/?page=1">1</a></li>
<li><a href="/?page=2">2</a></li>
<li><a href="/?page=3">3</a></li>
<li><a href="/?page=4">4</a></li>
</ul>
正如我们所看到的,索引从0开始。如果这是一个问题,您可以选择不使用索引,而是使用您想要的元素显式填充传递的切片。然后模板将如下所示:
const templ = `<ul>
{{range .}}
<li><a href="/?page={{.}}">{{.}}</a></li>
{{end}}
</ul>`
仅提供以2
开头的奇数的示例测试代码可能如下所示:
tmpl := template.Must(template.New("").Parse(templ))
n := 5
values := make([]int, n)
for i := range values {
values[i] = (i + 1) * 2
}
if err := tmpl.Execute(os.Stdout, values); err != nil {
panic(err)
}
这一次输出(在Go Playground上尝试):
<ul>
<li><a href="/?page=2">2</a></li>
<li><a href="/?page=4">4</a></li>
<li><a href="/?page=6">6</a></li>
<li><a href="/?page=8">8</a></li>
<li><a href="/?page=10">10</a></li>
</ul>
如果你不想打扰填充切片而你只需要从1开始增加数字,另一个选择是注册一个接收数字的函数,加1并返回结果。所以你可以继续使用零值切片的索引,你可以调用自定义函数来获得一个等于index + 1的数字:
func main() {
tmpl := template.Must(template.New("").Funcs(template.FuncMap{
"Add": func(i int) int { return i + 1 },
}).Parse(templ))
n := 5
if err := tmpl.Execute(os.Stdout, make([]struct{}, n)); err != nil {
panic(err)
}
}
const templ = `<ul>
{{range $idx, $e := .}}{{$idx := (Add $idx)}}
<li><a href="/?page={{$idx}}">{{$idx}}</a></li>
{{end}}
</ul>`
这一次输出(在Go Playground上尝试):
<ul>
<li><a href="/?page=1">1</a></li>
<li><a href="/?page=2">2</a></li>
<li><a href="/?page=3">3</a></li>
<li><a href="/?page=4">4</a></li>
<li><a href="/?page=5">5</a></li>
</ul>