如何在Go模板中传入“途中创建”的地图

问题描述 投票:0回答:1

我想在 Go 模板中制作类似 UI 组件 100% 可重用的东西,但我不知道是否可以做到。所以我正在尝试做下一步:

{{define "components/menu-button"}}
<a href="{{.link}}" class="text-white">{{.content}}</a>
{{end}}

这是我的组件,它需要一个

map
,因为属性是小写的。

然后在我的主页中,我有这个小菜单,它使用了导航栏中

components/menu-button
组件的 3 倍:

<div class="hidden gap-4 sm:flex">
    {{template "components/menu-button" {"link": "/contact", "content": "Contact"}}}
    {{template "components/menu-button" {"link": "/docs", "content": "Docs"}}}
    {{template "components/menu-button" {"link": "/download", "content": "Download"}}}
</div>

但我不知道是否可以以某种方式创建一个

map
,就像我在示例中所做的那样,它就像 JSON 一样,但我尝试过。

顺便说一句,它给了我下一个错误:

unexpected "{" in template clause
html go templates go-templates
1个回答
0
投票

Go 的模板不支持这种语法。

你可以做的是声明一个自定义函数,例如

func MakeMap(kvs ...any) map[any]any {
    m := make(map[any]any)
    for i := 0; i < len(kvs)-1; i+=2 {
        m[kvs[i]] = kvs[i+1]
    }
    return m
}

然后您可以使用

(*Template).Funcs
使该功能可用于模板,例如

t.Funcs(template.FuncMap{"M":MakeMap})

然后,在模板内,您可以使用键

M
调用该函数。

{{template "components/menu-button" (M "link" "/contact" "content" "Contact")}}

https://go.dev/play/p/Sl1ON-z7Mtn

© www.soinside.com 2019 - 2024. All rights reserved.