ASP.NET MVC页面UI之多级数据选择UI(行业信息、专业信息、职位信息的选择)
多级数据选择操作在开发中是常见的操作,比如选择行业信息时,一般有个大类,每个大类下边又包含很多小类,本文简单实现了弹出窗口一级一级选择功能。
本文博客出处:http://www.kwstu.com/ArticleView/admin_201392163458545 转载请注明!
一、效果图:


二、页面代码
<script src="../../Content/Js/selectlist.js"></script>
<script src="../../Content/Js/systools.js"></script>
<link href="../../Content/Css/kwstu.ui.css" rel="stylesheet" />
<script src="../../Content/Js/jquery.divbox.js"></script>
@Html.EditorFor(model => model.TRADENAME)@Html.HiddenFor(model => model.TRADEID)
三、JS代码
1、JS调用代码
$("#TRADENAME").focus(function () { GetTrade($(this).val(), "TRADENAME", "TRADEID", "/SysTools/GetFirstTradeList", "/SysTools/QueryLastTradeList", "/SysTools/GetOtherTradeList"); });
2、JS执行代码
//行业选择
function GetTrade(message, tmp1, tmp2, tmp3, tmp4, tmp5) {
name1 = tmp1; name2 = tmp2; url1 = tmp3; url2 = tmp4; url3 = tmp5;
//设置异步传输参数
var option = {
url: url1,
type: 'Get',
chche: false,
dataType: 'json',
data: { Message: message }, //发送服务器数据
success: function (data) { //成功事件
$("#kwstu_select ul li").die();
$("#kwstu_select").remove();
iptName = $(this).attr("id");
//var iptOffSet = $("#TRADENAME").offset();
//var iptLeft = iptOffSet.left;
//var iptTop = iptOffSet.top + 20;
var str = "<div id='kwstu_select'><span>请选择行业<a id='fh'>返回第一层列表</a> 快速查 找:<input id='kquery' type='text'/><font color=red>支持拼音首字母查询</font><a id='gb'>[ 关闭 ]</a></span><div id=info></div><ul></ul></div>";
var str2 = "";
$.each(data, function (i, item) {
str2 = str2 + "<li id='" + data[i].Value + "'>" + data[i].Text + "</li>";
});
$("body").append(str);
$("#kwstu_select ul").append(str2);
//$("#kwstu_select").css({ left: iptLeft + "px", top: iptTop + "px" });
$("#kwstu_select span a#fh").bind("click", function () {
$("#kwstu_select ul").empty();
$("#info").empty();
$("#info").hide();
$("#kwstu_select ul").append(str2);
});
$("#kwstu_select span a#gb").bind("click", function () {
$("#kwstu_select").CloseDiv();
});
$("#kwstu_select").OpenDiv();
//查询输入框获得焦点
$('#kquery').focus();
//快速查询
$("#kquery").focus(function () {
var bind_name = 'input';
if (navigator.userAgent.indexOf("MSIE") != -)
{ bind_name = 'propertychange'; }
$(this).bind(bind_name, function () {
var liId = $(this).attr("id");
var liText = $(this).val();
$("#info").show();
if (liText != "") {
var option = {
url: url2,
type: 'Get',
dataType: 'json',
data: { Message: liText }, //发送服务器数据
success: function (data) { //成功事件
listr = "";
$.each(data, function (i, item) {
listr = listr + "<li id='" + data[i].Value + "'>" + data[i].Text + "</li>";
});
$("#kwstu_select ul").empty();
$("#kwstu_select ul").append(listr);
},
error: function (XMLHttpRequest, textStatus, errorThrown) { //发送失败事件
alert(textStatus);
}
};
//进行异步传输
$.ajax(option);
}
})
})
$("#kwstu_select ul li").live("click", liBind);
},
error: function (XMLHttpRequest, textStatus, errorThrown) { //发送失败事件
alert(textStatus);
}
};
四、后台代码
///////////////////////////////行业联动下拉列表//////////////////////
/// 第一层行业
public ActionResult GetFirstTradeList(string message)
{
List<TSSYS_TRADE_BANK> list = db.TSSYS_TRADE_BANK.Where(c=>c.PID=="ROOT").OrderBy(c=>c.ID).ToList();
TSSYS_TRADE_BANK empty = new TSSYS_TRADE_BANK();
SelectList pList = new SelectList(list, "ID", "NAME");
return Json(pList, JsonRequestBehavior.AllowGet);
}
/// 第一层以后的行业
public ActionResult GetOtherTradeList(string message)
{
List<TSSYS_TRADE_BANK> list = db.TSSYS_TRADE_BANK.Where(c => c.PID == message).OrderBy(c => c.ID).ToList();
SelectList pList = new SelectList(list, "ID", "NAME");
return Json(pList, JsonRequestBehavior.AllowGet);
}
/// 快速查询
public ActionResult QueryLastTradeList(string message)
{
List<TSSYS_TRADE_BANK> list = db.Database.SqlQuery<TSSYS_TRADE_BANK>("Select ID,NAME,PID,SUBCLASSNO,SORT,ORDERNUM,EFFECT,ISSUB from TS.TSSYS_TRADE_BANK where (py(name) like '%" + message.ToUpper() + "%' or name like '%" + message + "%') and id not in (select pid from tssys_trade_bank) order by id").ToList();
SelectList pList = new SelectList(list, "ID", "NAME");
return Json(pList, JsonRequestBehavior.AllowGet);
}
五、相关资源下载
ASP.NET MVC页面UI之多级数据选择UI(行业信息、专业信息、职位信息的选择)的更多相关文章
- [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序更新相关数据
这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第八篇:为ASP.NET MVC应用程序 ...
- ASP.NET MVC应用程序更新相关数据
为ASP.NET MVC应用程序更新相关数据 这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译, ...
- 【ASP.NET MVC系列】浅谈ASP.NET MVC 视图与控制器传递数据
ASP.NET MVC系列文章 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google Chrome浏览器(操作 ...
- 【ASP.NET MVC系列】浅谈数据注解和验证
[ASP.NET MVC系列]浅谈数据注解和验证 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google C ...
- [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序读取相关数据
这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第七篇:为ASP.NET MVC应用程序 ...
- 解析ASP.NET Mvc开发之删除修改数据
目录: 1)从明源动力到创新工场这一路走来 2)解析ASP.NET WebForm和Mvc开发的区别 3)解析ASP.NET Mvc开发之查询数据实例 4)解析ASP.NET Mvc开发之EF延迟加载 ...
- ASP.NET MVC 5 学习教程:数据迁移之添加字段
原文 ASP.NET MVC 5 学习教程:数据迁移之添加字段 起飞网 ASP.NET MVC 5 学习教程目录: 添加控制器 添加视图 修改视图和布局页 控制器传递数据给视图 添加模型 创建连接字符 ...
- Asp.Net MVC页面静态化功能实现一:利用IHttpModule,摒弃ResultFilter
上一篇有提到利用IHttpModule和ResultFilter实现页面静态化功能.后来经过一些改动,将ResultFilter中要实现的功能全部转移到IHttpModule中来实现 Asp.Net ...
- Asp.Net MVC页面静态化功能实现一:利用IHttpModule和ResultFilter
由于公司现在所采用的是一套CMS内容管理系统的框架,所以最近项目中有一个需求提到要求实现页面静态化的功能.在网上查询了一些资料和文献,最后采用的是小尾鱼的池塘提供的 利用ResultFilter实现a ...
- 为ASP.NET MVC应用程序读取相关数据
为ASP.NET MVC应用程序读取相关数据 2014-05-08 18:24 by Bce, 299 阅读, 0 评论, 收藏, 编辑 这是微软官方教程Getting Started with En ...
随机推荐
- mysql_navicat_快捷键
快捷键能节省很多时间,之前一直研究oracle,plsql有自定义自动补全, 比如 sf 直接回车 可以出现 select * from 等等(参照http://www.cnblogs.com/cph ...
- Swift语言指南(一)--语言基础之常量和变量
原文:Swift语言指南(一)--语言基础之常量和变量 Swift 是开发 iOS 及 OS X 应用的一门新编程语言,然而,它的开发体验与 C 或 Objective-C 有很多相似之处. Swif ...
- zsh的安装与配置
参考: http://cnbin.github.io/blog/2015/06/01/mac-zsh-an-zhuang-he-shi-yong/ http://www.cnblogs.com/ios ...
- 使用Bootstrap
开始使用Bootstrap 作为一名Web开发者而言,如果不借助任何前端框架,从零开始使用HTML和CSS来构建友好的页面是非常困难的.特别是对于Windows Form的开发者而言,更是难上加难. ...
- STL源代码分析——STL算法sort排序算法
前言 因为在前文的<STL算法剖析>中,源代码剖析许多,不方便学习,也不方便以后复习.这里把这些算法进行归类,对他们单独的源代码剖析进行解说.本文介绍的STL算法中的sort排序算法,SG ...
- R - 变化plot字形,嵌入字体以pdf
近期使用R绘图遇到两个问题 1. 使用不同的字体 2. 保存 plot 至 pdf 当字体嵌入pdf (embed the font) 使用extrafont和Ghostscript能够解决这两个问题 ...
- ASP.NET MVC企业级项目框架
ASP.NET MVC企业级项目框架 MVC项目搭建笔记---- 项目框架采用ASP.NET MVC+Entity Framwork+Spring.Net等技术搭建,搭建过程内容比较多,结合了抽象工厂 ...
- NHibernate中使用memcache二级缓存
在NHibernate中使用memcache二级缓存 一.Windows下安装Memcache 1. 下载 http://jehiah.cz/projects/memcached-win32/ ...
- JSON解析之Gson
1.Gson简介 Gson是一个将Java对象转为JSON表示的开源类库,由Google提供,并且也可以讲JSON字符串转为对应的Java对象.虽然有一些其他的开源项目也支持将Java对象转为JSON ...
- Python开发环境Wing IDE使用教程:部分调试功能介绍
下面是用户应该了解的Wing IDE的其它一些调试功能: Main Debug File—用户可以指定项目中的一个文件作为调试的主入口点.当完成这个设置之后,调试总是从这个文件开始,除非用户使用Deb ...