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: 1, op: 'equal' }]
}), function (json) {
var lst = eval(json);
for (i = 0; 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 = 0; 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 = 0; 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;
}
做一个不断努力,积极向上的goodgirl-mia `(*∩_∩*)′。
 
分类: .net MVC
标签: jquery select

jquery+html三级联动下拉框的更多相关文章

  1. jquery+ligerform三级联动下拉框

    如下为ligerform里的三级联动下拉框: var formData=[ {display:,width:,space:,type:"select",group:"区域 ...

  2. jquery+html三级联动下拉框及详情页面加载时的select初始化问题

    html写的三个下拉框,如下: <select name="ddlQYWZYJ" id="ddl_QYWZYJ" class="fieldsel ...

  3. Android实现三级联动下拉框 下拉列表spinner

    Android实现(省.市.县)三级联动下拉框 下拉列表spinner 转载请注明出处: http://www.goteny.com/articles/2013/11/46.html http://w ...

  4. Web 1三级联动 下拉框 2添加修改删除 弹框

    Web  三级联动 下拉框 using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...

  5. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框

    JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP  mysql数据库  SpringMvc  ajax   Controller层  Service层  中国地区  省 ...

  7. JQ与AJAX 省市区三级联动下拉框

    用于初学者学习基本的联动下拉框,废话不多说,见代码 首先看控制器里的3个下拉框对应代码: public ActionResult GetProvinceList() { ProvinceReposit ...

  8. Android实现三级联动下拉框下拉列表spinner

    原文出处:http://www.cnblogs.com/zjjne/archive/2013/10/03/3350107.html 主要实现办法:动态加载各级下拉值的适配器 在监听本级下拉框,当本级下 ...

  9. JS(JQuery) 省市区三级联动下拉选择

    引入 area.js /* * 全国三级城市联动 js版 */ function Dsy(){ this.Items = {}; } Dsy.prototype.add = function(id,i ...

随机推荐

  1. 模拟Vue之数据驱动3

    一.前言 在"模拟Vue之数据驱动2"中,我们实现了个Observer构造函数,通过它可以达到监听已有数据data中的所有属性. 但,倘若我们想在某个对象中,新增某个属性呢? 如下 ...

  2. WPF学习(9)样式和行为

    在asp.net世界中,我们的美工人员会为我们准备好静态页面,它注意包括三个部分:html.css和js.而在WPF世界里,也同样有着类似这三个部分的静态页面:Xaml.Style和Behaviors ...

  3. HTTP请求中POST与GET的差别

    一.原理差别 一般我们在浏览器输入一个网址訪问站点都是GET请求;再FORM表单中,能够通过设置Method指定提交方式为GET或者POST提交方式,默觉得GET提交方式. HTTP定义了与serve ...

  4. axure & Markman

    axure & Markman学习总结 最近学了几款有意思的软件,一款是axure,另一款是Markman.接下来聊聊自己的学习心得吧. 关于axure,百度上的解释是:是一个专业的快速原型设 ...

  5. Java多线程总结之由synchronized说开去(转)

    这几天不断添加新内容,给个大概的提纲吧,方面朋友们阅读,各部分是用分割线隔开了的: synchronized与wait()/notify() JMM与synchronized ThreadLocal与 ...

  6. Cocos2d-x在线粒子编辑器

    自由.其效果是非常赞,可以手动调节和.出口可以上网plist档!. 住址:http://particle2dx.com/

  7. &quot;CoolReaper&quot; --酷派手机后门

    文章转自:http://drops.wooyun.org/tips/4342 注:译文未获得平底锅授权,纯属学习性质翻译 原文:https://www.paloaltonetworks.com/con ...

  8. Cannot update paths and switch to branch at the same time(转)

    当使用git进行操作: git checkout -b local-name origin/remote-name 出现错误: fatal: git checkout: updating paths ...

  9. MP4文件格式具体解释——结构概述

    MP4文件格式具体解释(ISO-14496-12/14) Author:Pirate Leo Email:codeevoship@gmail.com 一.基本概念 1. 文件,由很多Box和FullB ...

  10. 计数排序(C语言版本)

    让我们来谈谈数的排序思维: 计数排序假定待排序的全部元素都是介于0到K之间的整数.计数排序使用一个额外的数组countArray.当中第i个元素是待排序数组array中值等于i的元素的个数.然后依据数 ...