登录
首页 >  Golang >  Go问答

一个 Golang Web 模板中展示来自数据库多个表的表单

来源:stackoverflow

时间:2024-03-06 22:57:25 223浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《一个 Golang Web 模板中展示来自数据库多个表的表单》,聊聊,希望可以帮助到正在努力赚钱的你。

问题内容

我正在 golang 中做我的第一个项目,我正在尝试创建一个包含两个列表的表单以从中选择选项,如下所示:

带有表单的网页,它有两个可供选择选项的列表和一个文本字段

但是,如果我想让这些列表从 sqlite 数据库的两个表中检索其条目,模块“模板”只允许我为每个模板发送一个查询,例如

func person(w http.responsewriter, r *http.request) {
    db := connectdb()
    arrp := getperson(db)
    templates.executetemplate(w, "person", arrp)
}

因此,只有第一个列表将从范围中提取信息(在这种特殊情况下,它将显示“person”表中的有效选项,第二个列表将继续显示我自己硬编码的条目。

感谢@zombo 的回复。为了澄清一些事情,我发布的函数打开了与数据库的连接

db := connectdb()

然后它创建arrp(“person”类型的数组)并调用内置templates.executetemplate()

templates.executetemplate(w, "person", arrp)

这将呈现“person”html 模板。但是,在同一页面中,我尝试放置另一个选择表单来选择“服务”。如果我尝试类似的事情

func Person(w http.ResponseWriter, r *http.Request) {
    db := ConnectDB()
    arrP := GetPerson(db)
    arrS := GetService(db)
    templates.ExecuteTemplate(w, "person", arrP, arrS)
}

它会抱怨,因为我传递的参数比预期多。因此,只有人员名单才能与数据库中的信息正确呈现;但是,服务列表没有任何来源可以从中提取其条目。


正确答案


@zombo 给出了一个简洁的答案,使用 map 我们可以将多个数组传递给模板来渲染多个列表/表格。

map[string]any{“arrP”: arrP, “arrS”: arrS}

然后在 .tmpl 文件中使用 $.arrs

好了,本文到此结束,带大家了解了《一个 Golang Web 模板中展示来自数据库多个表的表单》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>