当前位置: 首页 > 面试题库 >

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

薄兴昌
2023-03-14
问题内容

场景:

我有一个级联方案,其中第二个下拉列表中的值首先取决于。我有三个模板“布局”,“输入”和“内部”。

尝试:

我正在对“输入”模板中的第一个下拉列表进行更改的ajax调用,并坚持处理返回的响应。目前,我找到了一种方法来替换第二个下拉列表的html来解决此问题。但是,我认为这不是更好的处理方法。我想要一些不需要修改html的渲染模板。

请以更好的方式帮助完成任务,或指向一些Wiki。 只有标准库

谢谢,

Layout.html http :
_//play.golang.org/p/LikKy6rf3-_

Input.html http :
_//play.golang.org/p/wM7EpPdXuM_

Inner.html http :
_//play.golang.org/p/xFpInKZfFT_

Main.go http :
_//play.golang.org/p/cxtJU-Lhi1_


问题答案:

在较高级别上,您有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 templates
values := ... // Load/construct the values
tmpl.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>从每个子项构造的新标签



 类似资料:
  • 本文向大家介绍android实现下拉菜单三级联动,包括了android实现下拉菜单三级联动的使用技巧和注意事项,需要的朋友参考一下 android中的下拉菜单联动应用非常普遍,android中的下拉菜单用Spinner就能实现,以下列子通过简单的代码实现三级菜单联动。 一 样式文件 二 联动逻辑代码 三 结果 四 总结 三级联动主要是灵活的应用三维数组,这样能很方便的通过数组索引将三个菜单关联,同

  • 本文向大家介绍javascript实现多级联动下拉菜单的方法,包括了javascript实现多级联动下拉菜单的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript实现多级联动下拉菜单的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的javascript程序设计有所帮助。

  • 问题内容: 我试图使用AngularJS创建一个链接/级联的下拉列表(选择元素),但是我很难用我的对象属性过滤和更新“ selected”属性。 首次加载页面时,所选项目将被过滤并正确显示在下拉菜单中。更改父级下拉菜单后,子级选择项不会抓住已过滤列表中的第一个项,导致子级下拉项不会更新。 任何见解将不胜感激,请注意,我将父/子/孙子数组分开(而不是在子数组中),因为最终我将从SQL中的单独spoc

  • 本文向大家介绍JavaScript省市级联下拉菜单实例,包括了JavaScript省市级联下拉菜单实例的使用技巧和注意事项,需要的朋友参考一下 最近学了一个关于省市级联简单的小例子,贴出来与大家分享一下: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍下拉菜单的级联操作(ajax),包括了下拉菜单的级联操作(ajax)的使用技巧和注意事项,需要的朋友参考一下 在开发中常常会遇到菜单的级联操作,比如:国家、城市、乡镇的选择等。当选中某个国家的时候,后面的菜单会把该国家内的城市罗列出来,当选中城市的时候,后面的菜单会把对应的乡镇列出来。  解决这种菜单的级联操作的办法,我理解的有两种: ①使用js来实现,把页面所用到的级联数据放到js

  • 本文向大家介绍javascript实现省市区三级联动下拉框菜单,包括了javascript实现省市区三级联动下拉框菜单的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript实现省市区三级联动下拉框菜单代码。分享给大家供大家参考,具体如下 运行效果截图如下: 首先写一个静态的页面: 调用的geo.js源码: