下拉列表联动显示(Car表) 三级联动
、Models
namespace 下拉列表联动显示_Car表_.Models
{
public class ProductorBF
{
private MyDBDataContext _context=new MyDBDataContext();
public List<productor> Select() //厂商全部显示
{
return _context.productor.ToList();
} }
} namespace 下拉列表联动显示_Car表_.Models
{
public class BrandBF
{
private MyDBDataContext _context = new MyDBDataContext();
public List<brand> Select() //品牌(系列)全部显示
{
return _context.brand.ToList();
}
public List<brand> SelectByProd(string prod) //根据汽车厂商查汽车品牌
{ var query = _context.brand.Where(P => P.prod_code == prod);
if (query.Count() > )
{
return query.ToList();
}
else
{
return null;
} }
}
} namespace 下拉列表联动显示_Car表_.Models
{
public class CarBF
{
private MyDBDataContext _context = new MyDBDataContext();
public List<car> Select() //汽车全部显示
{
return _context.car.ToList();
}
public List<car> SelectByBrand(string brand_code) //根据汽车品牌查具体汽车
{
var query = _context.car.Where(P => P.brand==brand_code);
if (query.Count() > )
{
return query.ToList();
}
else
{
return null;
}
}
}
} 、Controllers
namespace 下拉列表联动显示_Car表_.Controllers
{
public class HomeController : Controller
{ [HttpGet]
public ActionResult Index()
{
//厂家表(强类型)
List<productor> list =new ProductorBF().Select();
SelectList aaa = new SelectList(list,"prod_code","prod_name","p001"); //品牌表
List<brand> list1 = new BrandBF().SelectByProd("p001");
SelectList bbb1 = new SelectList(list1, "brand_code", "brand_name");
ViewBag.bbb = bbb1; //汽车表
List<car> cars = new CarBF().SelectByBrand("b001");
SelectList ccc1 = new SelectList(cars,"code","name");
ViewBag.ccc = ccc1; return View(aaa);
} [HttpPost]
public ActionResult Index(string prodcode,string brandcode,string carcode)
{
//厂家表(强类型)
List<productor> list1 = new ProductorBF().Select();
SelectList aaa = new SelectList(list1, "prod_code", "prod_name",prodcode); //品牌表
List<brand> list2 = new BrandBF().SelectByProd(prodcode);
SelectList bbb1 = new SelectList(list2,"brand_code","brand_name",brandcode);
ViewBag.bbb = bbb1; //汽车表
//两种情况:选厂商的时候,判断一下加载的系列在不在当前厂商下
//1、在的话,直接根据加载出来的系列代号查
//2、不在的话,根据新选的厂商加载出来系列的第一个查
var b = list2.Exists(P => P.brand_code == brandcode) ? brandcode : list2[].brand_code; //假设选的是P003,但是定位的Brand是B001,所有需要判断,如果品牌里的下拉列表里有一个代号等于传进来的brand,说明有,可以查;如果不包含,需要根据你提交的厂商查出来的品牌中的第一项来查
List<car> list3 = new CarBF().SelectByBrand(b);
SelectList ccc1 = new SelectList(list3,"code","name",carcode);
ViewBag.ccc = ccc1; return View(aaa);
} }
} 、Views
@using 下拉列表联动显示_Car表_.Models;
@model SelectList
@{
Layout = null;
} <!DOCTYPE html> <html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
@using (Html.BeginForm("Index", "Home", FormMethod.Post))
{
//new { onchange="document.forms[0].submit();"} 文本一旦改变整个表单会跟着变
@Html.DropDownList("prodcode", Model,new { onchange="document.forms[0].submit();"});
@Html.DropDownList("brandcode", ViewBag.bbb as SelectList,new { onchange="document.forms[0].submit();"});
@Html.DropDownList("carcode", ViewBag.ccc as SelectList); }
</div>
</body>
</html>
效果图:
下拉列表联动显示(Car表) 三级联动的更多相关文章
- Python实现用户交互,显示省市县三级联动的选择
题目:Python实现用户交互,显示省市县三级联动的选择 定义的字典为: dic = { "江西": { "萍乡": ["安源", &quo ...
- 根据参数显示类别(三级联动,需要JSON数据)
根据参数显示类别(三级联动,需要JSON数据) Scripts/Category.js 调用方法: $(function () { BindCategory(); //默认绑定文本框中的值 BindC ...
- 三级联动第二种方法 三级联动.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 三级联动第二种方法 三级联动数据.js
var data = { '0':{2:'北京',25:'天津',24:'上海',31:'重庆',130000:'河北省',140000:'山西省',150000:'内蒙古自治区',210000:'辽 ...
- css 实现三级联动菜单
昨天因为项目中想要把二级联动菜单改成三级联动菜单,所以我就单独写了一个tab导航栏,用纯css的方式实现的三级联动.一开始我想着可以用js实现,但是js的hover事件和mouseenter,mous ...
- EasyuiCombobox三级联动
有许多刚接触Easyui中Combobox控件的朋友可能都会遇到的问题:如何将Combobox做成三级联动? 先本人有个三级联动的案例给大家参考参考,经测试能通过.注意Combobox绑定的数据是Js ...
- JS——EasyuiCombobox三级联动
有许多刚接触Easyui中Combobox控件的朋友可能都会遇到的问题:如何将Combobox做成三级联动? 现分享一个三级联动的案例给大家参考参考,经测试能通过.注意Combobox绑定的数据是Js ...
- Vue如何使用vue-area-linkage实现地址三级联动效果
很多时候我们需要使用地址三级联动,即省市区三级联动.网上有很多插件,在此介绍Vue的一款地区联动插件:vue-area-linkage,下面介绍如何使用这个插件实现地址联动效果: 1. ...
- PHP ajax 实现三级联动
在一个单独JS页面中,利用ajax实现三级联动,做成一个三级联动形式,以便于以后随时调用 JS代码: $(document).ready(function(e) { $("#sanji&qu ...
随机推荐
- linux 判断指定用户对指定目录具有的权限
脚本名:power.sh 脚本内容: ------------------------------------------- 注意:必须以root 身份执行该脚本. 脚本power.sh 需要两个参数 ...
- jQuery队列控制方法详解queue()/dequeue()/clearQueue()
queue(name,[callback]): 当只传入一个参数时, 它返回并指向第一个匹配元素的队列(将是一个函数数组,队列名默认是fx);$('#demo').queue('name') 当有两 ...
- Cassandra1.2文档学习(7)—— 规划集群部署
数据参考:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/architecture/a ...
- Socket 入门
int socket(int domain, int type,int protocol) domain :说明我们网络程序所在的主机采用的通讯协族(AF_UNIX和AF_INET等). AF_UNI ...
- python学习_应用pickle模块封装和拆封数据对象
学习文件数据处理的时候了解到有pickle模块,查找官方文档学习了一些需要用到的pickle内容. 封装是一个将Python数据对象转化为字节流的过程,拆封是封装的逆操作,将字节文件或字节对象中的字节 ...
- 大坑!常被忽视又不得不注意的小细节——%I64,%lld与cout(转载)
原地址:http://blog.csdn.net/thunders01/article/details/38879553 刚刚被坑完,OI一年了才知道%I64和%lld有区别(做题会不会太少),lon ...
- ubuntu 12.04 安装 nginx+php+mysql web服务器
Nginx 是一个轻量级,以占用系统资源少,运行效率而成为web服务器的后起之秀,国内现在很多大型网站都以使用nginx,包括腾讯.新浪等大型信息网站,还有淘宝网站使用的是nginx二次开发的web服 ...
- com.mchange.v2.c3p0.ComboPooledDataSource
C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSourc ...
- windows8.1专业中文版一个可用的密钥分享
分享一个windows8.1专业中文版一个可用的密钥,亲测可用,联网输入密钥激活即可. PKHMN-TWQ6R-XDTH7-P4WW4-YR9T7
- 【实用技巧】文件MD5修改方法
方法一 利用md5修改器 更新日志:2011-10-6 22:00修正对于路径中存在空格修改无效的bug2011-10-6 20:17更新:1.回归简约界面2.直接拖拽即可捕获地址3.一键修改文件 ...