zoukankan      html  css  js  c++  java
  • asp.net mvc 两级分类联动方法示例


    前台视图代码

    <%:Html.DropDownList("AwardClassMainID","请选择")%>

    <%:Html.DropDownList("SubID",new List<SelectListItem> { (new SelectListItem(){Text="请选择",Value="0"})})%>

    //jquery代码

          $("#AwardClassMainID").change(function () {

                   var url ="../AwardSubClasic/GetClasicList/"; //规则是控制器/方法/参数

                   $.getJSON(url, { firstclassid:$("#AwardClassMainID").val() }, function (data) {

                       $('#SubID').html('');

                       $('#SubID').append("<optionvalue=0>请选择</option>")

                       $.each(data, function (i,item) {

    $('#SubID').append($("<option></option>").val(item.SecondClassID).html(item.ClassName));

                       });

                   });

              });

    后台Controller里代码

    //view里面加一级分类的数据

    ViewBag.AwardClassMainID = new SelectList(bll.GetAll(),"ClassID", "ClassName");

    <summary>

    /// json返回数据-通过分类ID,查询此分类的二级分类

    /// </summary>

    /// <param name="id">一级分类ID</param>

    /// <returns></returns>

    [HttpGet]

    public JsonResult GetClasicList(string firstclassid)

    {

     List< TrainingSecondClass > Classlist = m_BLL.GetClassDropDwonList(firstclassid);

     return Json(Classlist.ToList<AwardSubClasic>(),JsonRequestBehavior.AllowGet);

    }

    IBLL里面加接口声明

    List<TrainingSecondClass>GetClassDropDwonList(string id);

    BLL里面

    public List<TrainingSecondClass> GetClassDropDwonList(stringid)

          {

              return repository.GetClassDropDwonList(db,id).ToList<TrainingSecondClass>();

          }

    repository里面加实现方法

           public List<TrainingSecondClass>GetClassDropDwonList(SysEntities db, string FirstClassID)

          {

              List<TrainingSecondClass> result =new List<TrainingSecondClass>();

              var n = db.TrainingSecondClass.Where(p => p.FirstClassID ==FirstClassID).ToList();

              foreach (var c in n)

              {

                   result.Add(new TrainingSecondClass

                   {//取出json调用的数据

                       SecondClassID =c.SecondClassID,

                       ClassName = c.ClassName

                   });

              }

              return result;

          }

  • 相关阅读:
    使用qemu模拟调试内核和debian根文件系统
    qemu无界面启动,并重定向输出到终端
    linux 音频编程
    解决Android中No resource found that matches android:TextAppearance.Material.Widget.Button.Inverse问题
    【BigData】Java基础_通用排序工具类的实现
    【BigData】Java基础_登录注册实现
    【费曼学习方法】世界上最好的学习方法
    【BigData】Java基础_接口
    【BigData】Java基础_Eclipse配置自动补全new
    【BigData】Java基础_HashSet
  • 原文地址:https://www.cnblogs.com/javawebsoa/p/3231099.html
Copyright © 2011-2022 走看看