栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何使用golang的模板实现级联下拉菜单

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何使用golang的模板实现级联下拉菜单

在较高级别上,您有2个选项:

  • 发送下拉列表的所有值(例如,作为树),并在较高级别的下拉列表更改时更改第二级和第三级的值(适用于小型列表,不适用于大型数据集)
  • 或您选择的一个:当选择更改时,您将进行AJAX调用(从触发
    onchange
    ),然后从结果中填充列表。

详细说明2:从AJAX调用结果中填充列表

您还可以通过以下两种方法执行此操作:

  • AJAX调用都会返回HTML调用,您可以简单地使用它们来替换HTML

    <select>
    标签的内部HTML 。

  • 或者,AJAX调用可能仅返回数据(例如,使用JSON编码),而Javascript代码可以构建列表的内容。

AJAX返回HTML

AJAX调用可能会返回需要替换的完整HTML代码作为的内部HTML

<select>
。要在服务器端实现此目的,您可以创建/分离仅负责生成此HTML代码的HTML模板,例如:

{{define "innerList"}}    {{range .}}        <option value="{{.Key}}">{{.Text}}</option>    {{end}}{{end}}

您只能执行以下模板:

// tmpl is the collection of your templatesvalues := ... // Load/construct the valuestmpl.ExecuteTemplate(w, "innerList", values)

values
是以下结构的一部分:

type Pair struct {    Key string    Text string}

<select>
用Javascript 构建内容

AJAX调用可能返回JSON数据结构,即成对的数组/

value;text
对列表,您可以
<option>
自己从中添加子标签。

要将添加

<option>
到一个
<select>
标签:

var x = document.getElementById("mySelect");var option = document.createElement("option");option.value = "1234";option.text = "Kiwi";x.add(option);

因此,基本上,您需要做的是删除的当前子项

<select>
,遍历作为响应收到的列表,并添加一个
<option>
从每个子项构造的新标签。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/484220.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号