、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表) 三级联动的更多相关文章

  1. Python实现用户交互,显示省市县三级联动的选择

    题目:Python实现用户交互,显示省市县三级联动的选择 定义的字典为: dic = { "江西": { "萍乡": ["安源", &quo ...

  2. 根据参数显示类别(三级联动,需要JSON数据)

    根据参数显示类别(三级联动,需要JSON数据) Scripts/Category.js 调用方法: $(function () { BindCategory(); //默认绑定文本框中的值 BindC ...

  3. 三级联动第二种方法 三级联动.html

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. 三级联动第二种方法 三级联动数据.js

    var data = { '0':{2:'北京',25:'天津',24:'上海',31:'重庆',130000:'河北省',140000:'山西省',150000:'内蒙古自治区',210000:'辽 ...

  5. css 实现三级联动菜单

    昨天因为项目中想要把二级联动菜单改成三级联动菜单,所以我就单独写了一个tab导航栏,用纯css的方式实现的三级联动.一开始我想着可以用js实现,但是js的hover事件和mouseenter,mous ...

  6. EasyuiCombobox三级联动

    有许多刚接触Easyui中Combobox控件的朋友可能都会遇到的问题:如何将Combobox做成三级联动? 先本人有个三级联动的案例给大家参考参考,经测试能通过.注意Combobox绑定的数据是Js ...

  7. JS——EasyuiCombobox三级联动

    有许多刚接触Easyui中Combobox控件的朋友可能都会遇到的问题:如何将Combobox做成三级联动? 现分享一个三级联动的案例给大家参考参考,经测试能通过.注意Combobox绑定的数据是Js ...

  8. Vue如何使用vue-area-linkage实现地址三级联动效果

    很多时候我们需要使用地址三级联动,即省市区三级联动.网上有很多插件,在此介绍Vue的一款地区联动插件:vue-area-linkage,下面介绍如何使用这个插件实现地址联动效果:         1. ...

  9. PHP ajax 实现三级联动

    在一个单独JS页面中,利用ajax实现三级联动,做成一个三级联动形式,以便于以后随时调用 JS代码: $(document).ready(function(e) { $("#sanji&qu ...

随机推荐

  1. [转]js中几种实用的跨域方法原理详解

    转自:js中几种实用的跨域方法原理详解 - 无双 - 博客园 // // 这里说的js跨域是指通过js在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同 ...

  2. Windows下查询进程、端口

    PID --> 端口号netstat -ano | findstr 8244 端口号 --> PIDnetstat -aon|findstr "11211" PID - ...

  3. python拆分excel脚本

    因为需要将一个很大的excel按500条拆分为多个excel,手工操作实在太麻烦,就写了个python小脚本,现在是分为了多个sheet页,使用者可根据自己实际情况修改成多个文件的形式 #!/usr/ ...

  4. C语言中的%0nd,%nd,%-nd

    C语言中的%0nd printf --> formatted print/格式化输出 一.十进制 d -> decimal/十(shí)进制 int a=1; int b=1234; do ...

  5. java File详解

    一.简介 File类是“文件”和“目录名”的抽象表示形式.因此在java语言中,File类既可以表示文件也可以表示目录. 尽管java.io定义的大多数类是实行流式操作的,而File类则不是,它没有指 ...

  6. Java中的面向对象

    Java中的面向对象 在软件开发的学习中, 我最先接触的开发语言就是java,但都是简单的函数和循环数组的应用.说道面向对象,第一次看到这个词的时候还是在C#的学习过程中,我记得当时PPT上霸气的解释 ...

  7. java nio使用方法(转)

    最近由于工作关系要做一些Java方面的开发,其中最重要的一块就是Java NIO(New I/O),尽管很早以前了解过一些,但并没有认真去看过它的实现原理,也没有机会在工作中使用,这次也好重新研究一下 ...

  8. windows phone 网易云阅读hubtile效果实现

    效果图 曾几何时,刚接触wp的时候做了一个类似的界面,不过是Rectangle实现的,还是一个个摆的..囧啊 现在感觉这种应该是用hubtile实现的,Toolkit(http://silverlig ...

  9. 使用.htaccess进行浏览器图片文件缓存

    对于图片类网站,每次打开页面都要重新下载图片,慢不说,还非常浪费流量.这时就需要用到缓存,强制浏览器缓存图片文件 缓存文件,提问网站访问数度,减少流量消耗,现提供2中缓存代码 打开.htaccess文 ...

  10. 修改VC++2010界面左上角图标

    (1)在Resource View中创建或者插入一个新的Icon资源,用于你想要的程序图标,假设ID号为IDI_ICON(这种图标要有16*16和32*32两种格式的,前者用于最小化和列表显示等,后者 ...