jquery+html三级联动下拉框及详情页面加载时的select初始化问题
html写的三个下拉框,如下:
<select name="ddlQYWZYJ" id="ddl_QYWZYJ" class="fieldsel" style="width: 200px;font-size:12px" ></select>
<select name="ddlQYWZEJ" id="ddl_QYWZEJ" class="fieldsel" style="width: 200px;font-size:12px"></select>
<select name="ddlQYWZSJ" id="ddl_QYWZSJ" class="fieldsel" style="width: 200px;font-size:12px"></select>
要求1:加载页面时初始化一级下拉框,当一级下拉框点击取值后加载二级下拉框,点击二级下拉框后加载三级下拉框;
$(document).ready(function () {
//一级单位的下拉显示框
$.getJSON(rootPath + 'Dictionary/GetDicDataForSelect?idfield=ID&textfield=VALUE&' + "where=" + JSON2.stringify({
op: 'and',
rules: [{ field: 'PARENTID', value: , op: 'equal' }]
}), function (json) {
var lst = eval(json);
for (i = ; i < lst.length; i++) {
var tname = lst[i].text;
var tid = lst[i].id;
$("#ddl_QYWZYJ").append("<option value='" + tid + "'>" + tname + "</option>");
}
});
$("#ddl_QYWZYJ").click(function () {
GetQYWZYJData();
});
$("#ddl_QYWZEJ").click(function () {
GetQYMSData();
})
})
@* 一级下拉框值改变时触发加载二级下拉框*@
function GetQYWZYJData() {
var QYWZYJvalue = $('#ddl_QYWZYJ option:selected').val();//选中的文本
$.getJSON(rootPath + 'Dictionary/GetDicDataForSelect?idfield=ID&textfield=VALUE&' + "where=" + JSON2.stringify({
op: 'and',
rules: [{ field: 'PARENTID', value: QYWZYJvalue, op: 'equal' }]
}), function (json) {
$("#ddl_QYWZEJ").html("");//清空下拉框
$("#txt_QYMS").html("");//清空区域描述
var lst = eval(json);
for (var i = ; i < lst.length; i++) {
$("#ddl_QYWZEJ").append("<option value='" + lst[i].id + "'>" + lst[i].name + "</option>");
}
})
}
@* 二级下拉框值改变时触发加载三级下拉框*@
function GetQYMSData() {
var QYWZEJvalue = $('#ddl_QYWZEJ option:selected').val();//选中的文本
if (QYWZEJvalue == null) return;
$.getJSON(rootPath + 'Dictionary/GetDicDataForSelect?idfield=ID&textfield=VALUE&' + "where=" + JSON2.stringify({
op: 'and',
rules: [{ field: 'ID', value: QYWZEJvalue, op: 'equal' }]
}), function (json) {
$("#ddl_QYWZSJ").html("");
var lst = eval(json);
for (var i = ; i < lst.length; i++) {
$("#ddl_QYWZSJ").append("<option value='" + lst[i].id + "'>" + lst[i].name + "</option>");
}
})
}
要求2:选择三个下拉框,分别把三个选中的text值保存在一个表(如XX表)中,当加载详情页面时,读取XX表中该记录保存的下拉框选中的text值,初始化三个下拉框。
这时,需要注意的是option的value与text值。value是下拉框选项的取值,不显示在页面中;text为文本显示值,我们在页面中看到的是text值。
针对下拉框select,我们建了一个实体类LigerUISelect。如下代码
/// <summary>
/// LigerUI中Select的实体类
/// </summary>
public class LigerUISelect
{
#region - 属性 - /// <summary>
/// id
/// </summary>
public int id { get; set; }
/// <summary>
/// 显示内容
/// </summary>
public string text { get; set; } /// <summary>
/// 将实体转为为Select列表
/// </summary>
/// <param name="department"></param>
/// <returns></returns>
public static LigerUISelect ToViewModel(tbDictionary dict)
{
LigerUISelect item = new LigerUISelect();
item.id = dict.ID; //注意,select类的ID等于字典表记录ID字段
item.text = dict.VALUE; //select类的text等于字典表记录的Value字段
return item;
}
}
上面构造的select实体类中的属性id(对应option value)=dict.ID,和text(对应option text)=dict.VALUE。ID和text的值不一致,注意到代码出现一个字典表tbDictionary——dict.ID:字典ID,dict.VALUE:字典值;而保存在XX表的三个下拉框取值是option text值(即对应select实体类中的text值,也是对应字典表中的VALUE值)。
select初始化时,是根据option value来初始化值的,但是从数据库读取出的是option text值,所以匹配不上的话,则select初始化值不显示。因此,需要把读出的option text的值转化为option value。
那么问题来了,如何转化呢?
前面已经说了,XX表保存的下拉框取值是option text,前面也提到,option text对应select实体类的text属性,也对应了字典表中的VALUE字段;option value对应了select实体类的ID属性,也对应了字典表ID字段。
因此,把option text转化为其option value,实质上就是在字典表中根据VALUE字段值找出其对应的ID值!
所以问题就简单了,如下代码即可转化:
DictionaryService和IDictionaryService分别是字典表tbdicitonary实体模型对应的BLL层中的构造函数及其接口函数。
IDictionaryService areaService = new DictionaryService();
//根据值转换成对应的ID
data.QYYJ = areaService.GetEntity(p => p.VALUE == data.QYYJ) == null ?"" : areaService.GetEntity(p => p.VALUE == data.QYYJ).ID.ToString();
其实,针对要求2,还可以用一个更简单的方法实现。 LigerUI中Select实体类中的id和text的值写成一致即可。这样option value和option text值也一致,就能直接能初始化select值,不需要转化了。如下代码:
/// <summary>
/// LigerUI中Select的实体类
/// </summary>
public class LigerUISelect
{
#region - 属性 - /// <summary>
/// id
/// </summary>
public string id { get; set; } /// <summary>
/// 显示内容
/// </summary>
public string text { get; set; } /// <summary>
/// 将实体转为为Select列表
/// </summary>
/// <param name="department"></param>
/// <returns></returns>
public static LigerUISelect ToViewModel(tbDictionary dict)
{
LigerUISelect item = new LigerUISelect();
item.id = dict.VALUE; //id和text都等于字典值VALUE
item.text = dict.VALUE;
return item;
}
}
前端View页面中对select的初始化语句:
function LoadData() {
LG.ajax(
{
url: rootPath1 + 'ReportsGenerate/GetCSBDataToUI',
loading: '正在加载...',
data: {
ID: ywid
},
success: function (result) {
if (!result) {
LG.showError("加载失败!");
return false;
}
else {
LoadControlData(result);
}
},
error: function (message) {
LG.showError("加载失败!");
}
})
}
@*给控件赋值*@
function LoadControlData(result) {
document.getElementById('ddl_QYWZYJ').value = result.QYWZYJ;
document.getElementById('ddl_QYWZEJ').value = result.QYWZEJ;
document.getElementById('txt_QYWZSJ').value = result.QYWZSJ;
}
jquery+html三级联动下拉框及详情页面加载时的select初始化问题的更多相关文章
- jquery+html三级联动下拉框
jquery+html三级联动下拉框及详情页面加载时的select初始化问题 html写的三个下拉框,如下: <select name="ddlQYWZYJ" id=&q ...
- jquery+ligerform三级联动下拉框
如下为ligerform里的三级联动下拉框: var formData=[ {display:,width:,space:,type:"select",group:"区域 ...
- Android实现三级联动下拉框 下拉列表spinner
Android实现(省.市.县)三级联动下拉框 下拉列表spinner 转载请注明出处: http://www.goteny.com/articles/2013/11/46.html http://w ...
- Web 1三级联动 下拉框 2添加修改删除 弹框
Web 三级联动 下拉框 using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...
- JS年月日三级联动下拉框日期选择代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框
JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP mysql数据库 SpringMvc ajax Controller层 Service层 中国地区 省 ...
- JQ与AJAX 省市区三级联动下拉框
用于初学者学习基本的联动下拉框,废话不多说,见代码 首先看控制器里的3个下拉框对应代码: public ActionResult GetProvinceList() { ProvinceReposit ...
- Android实现三级联动下拉框下拉列表spinner
原文出处:http://www.cnblogs.com/zjjne/archive/2013/10/03/3350107.html 主要实现办法:动态加载各级下拉值的适配器 在监听本级下拉框,当本级下 ...
- JS(JQuery) 省市区三级联动下拉选择
引入 area.js /* * 全国三级城市联动 js版 */ function Dsy(){ this.Items = {}; } Dsy.prototype.add = function(id,i ...
随机推荐
- RH253读书笔记(6)-Lab 6 Implementing Web(HTTP) Services
Lab 6 Implementing Web(HTTP) Services Goal: To implement a Web(HTTP) server with a virtual host and ...
- Linux
介绍了相关的文件夹
学习Linux,先了解Linux标准的文件夹结构是非常重要的,学习的一个很好的铺垫之后的行动.去罗列大而全的所有文件夹. 本文主要说明.笔者本人接触,须要了解的一些文件文件夹,当然本文也会不断的更新或 ...
- mysql位_01检查错误代码的方法
1 看到官方帮助文档 当前最新版本号的错误码见 http://dev.mysql.com/doc/refman/5.7/en/error-handling.html 2 在安装mysql的环境中调用m ...
- 每天收获一点点------Hadoop RPC机制的使用
一.RPC基础概念 1.1 RPC的基础概念 RPC,即Remote Procdure Call,中文名:远程过程调用: (1)它允许一台计算机程序远程调用另外一台计算机的子程序,而不用去关心底层的网 ...
- ECLIPSE IDEA 调音 1
为自己所用IDE进行jvm优 首先进行日志输出配置 Eclipse 改动eclipse.ini IDEA 改动 idea.exe.vmoptions 添加打印日志的配置參数 -XX:+Print ...
- 优秀团队建设--美国式团队(ppt)
美国式团队 一.团队精神 团队精神反映一个人的素养.一个人的能力,一个人与别人合作的精神和能力.一个团队是个有机的总体,作为个人,仅仅有全然融入到这个有机总体之中,才干最大限度地体现自己的价值. 团队 ...
- Git 常用命令手记 及 Github协同流程(转)
符号约定俗成:<xxx> 自定义内容xxx:[xxx] xxx为可选项:[<xxx>] 自定义内容xxx且为可选项. 说明/备注 命令 备注 保存更新 git add [-i] ...
- C# 实现对接电信交费易自动缴费 续(winio/winring0 自动填密码)
原文:C# 实现对接电信交费易自动缴费 续(winio/winring0 自动填密码) 自动填密码大家可能都不莫生,最有名的应该是 按键精灵 只要是一个可以输入的地方都可以能过按键精灵来完成输入.我今 ...
- Kinect SDK C++ - 2. Kinect Depth Data
Today we will learn how to get depth data from a kinect and what the format of the data is kinect co ...
- 查询出各个学科的前3名的同学信息的Sql
查找各个学科的成绩前3名的学生信息Sql,有2种方法,一种是利用sql的row_number() over()函数,另一种是用子查询, 表设计如下 如果不考虑各个学科的成绩有并列的情况的话,有如下两种 ...