jquery+html三级联动下拉框
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;
}

jquery+html三级联动下拉框的更多相关文章
- jquery+ligerform三级联动下拉框
如下为ligerform里的三级联动下拉框: var formData=[ {display:,width:,space:,type:"select",group:"区域 ...
- jquery+html三级联动下拉框及详情页面加载时的select初始化问题
html写的三个下拉框,如下: <select name="ddlQYWZYJ" id="ddl_QYWZYJ" class="fieldsel ...
- 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 ...
随机推荐
- 原生js实现 常见的jquery的功能
原生选择器 充分利用 bind(this)绑定 <div id="box"> <ul> <li >111 </li> <l ...
- JAVA该队列中的数组,圆阵队列,链队列
/** * 文件名:QueueText.java * 时间:2014年10月22下午9:05:13 * 笔者:维亚康姆维修 */ package chapter3; /** * 类名:ArrayQue ...
- JavaEE(10) - Session EJB的依赖注入、引用及任务调度
1. EJB依赖注入 #1. EJB开发(Net Beans创建EJB Module, 项目名称:CallHello) Hello.java package org.crazyit.service; ...
- 基于Haar特征Adaboost人脸检测级联分类
基于Haar特征Adaboost人脸检测级联分类 基于Haar特征Adaboost人脸检测级联分类,称haar分类器. 通过这个算法的名字,我们能够看到这个算法事实上包括了几个关键点:Haar特征.A ...
- PHP从零单排(十八)图像处理
1.打开现有的图像 <?php header("Content-type:image/jpeg"); $img=imagecreatefromjpeg("cc.jp ...
- Oracle 使用
Oracle 日志文件 摘要: 本篇博文呢主要是介绍 Oracle 日志文件的管理, 对 Oracle 日志文件呢,有两个比较关键的名词, 即日志文件组 LogFileGroup 和日志文件 LogF ...
- 大数据系列修炼-Scala课程03
前言 今天上班看了很多关于前端js,jQuery.bootstrap.js以及springMVC看得迷迷糊糊的,毕竟以前很少去学习前端的技术,所有看得有点困,还好看得比较多,回家后也开始学习关于Sca ...
- iOS设备per app vpn,什么是什么系统的要求,必须?
坑爹Apple网站信息MDM厂商资料,最有发言权iOS 7.x设备支持per app vpn该,但它没有说明是什么系统要求环保要求. 1. iOS 7.x 设备.当然 2. iOS 7.x 需要设备M ...
- oracle_常用命令(表空间查询)
---查询表空间 对应的物理文件,名称 ,大小 ,已用的,利用率 SELECT B.FILE_NAME "FILE_NAME", B.TABLESPACE_NAME "T ...
- 基于Qt语音识别功能
基于在最近的研究Qt语音识别平台下.在此记录12 首先,语音识别做三件事 1.记录用户的语音文件到本地 2.将用户语音编码 使用flac或者speex进行编码 3.使用第三方语音识别API或者SDK进 ...