asp.net mvc Dropdownlist获取数据库中某字段的值

controller层获取数据库中某字段的值,然后由view层接收。

controller层代码如下:

      public ActionResult Index(string movieGenre,string searchString)
        {
            var GenreLst = new List<string>();

            var GenreQry = from d in db.Movies
             orderby d.Genre
              select d.Genre;

            GenreLst.AddRange(GenreQry.Distinct());
            //GenreLst.Add("test");
            //GenreLst.Add("ss");

            ViewBag.movieGenre = new SelectList(GenreLst);

            var movies = from m in db.Movies
                         select m;

            if (!String.IsNullOrEmpty(searchString))
            {
                movies = movies.Where(s => s.Title.Contains(searchString));
            }

            if (!string.IsNullOrEmpty(movieGenre))
            {
                movies = movies.Where(x => x.Genre == movieGenre);
            }

            return View(movies);
        }

view层代码如下;

<p>
    @Html.ActionLink("Create New", "Create")
    @using (Html.BeginForm("Index","Movies",FormMethod.Get)){
        <p>
        Genre:@Html.DropDownList("movieGenre","All")
        Title:@Html.TextBox("SearchString") 
        <input type="submit" value="搜索" />
        </p>
    }
</p>



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ASP.NET MVC的下拉列表联动是一种常见的需求,它可以实现当一个下拉列表的选项发生改变时,另一个下拉列表的选项也随之改变。下面是我用300字回答的步骤: 1. 首先,创建两个Model来表示这两个下拉列表的选项。例如,一个是CountryModel,另一个是CityModel。这两个Model都需要包含相应的属性,如CountryId和CountryName,CityId和CityName。 2. 在Controller,创建两个Action来获取这两个下拉列表的选项。例如,一个是GetCountryList,另一个是GetCityList。这两个Action应该返回相应的选项数据,例如通过调用数据库获取国家和城市的数据,并将其转换为对应的Model列表。 3. 在View,使用HTMLHelper的DropDownListFor方法创建两个下拉列表。第一个下拉列表使用CountryId作为选,并指定一个名为CountryList的ViewBag变量作为选项列表。第二个下拉列表使用CityId作为选,并指定一个名为CityList的ViewBag变量作为选项列表。例如: @Html.DropDownListFor(model => model.CountryId, (IEnumerable<SelectListItem>)ViewBag.CountryList, "-请选择国家-") @Html.DropDownListFor(model => model.CityId, (IEnumerable<SelectListItem>)ViewBag.CityList, "-请选择城市-") 4. 使用jQuery监听第一个下拉列表的change事件,当选发生改变时,触发一个Ajax请求。例如: $("#CountryId").change(function() { var selectedCountryId = $(this).val(); $.ajax({ url: '/Controller/GetCityList', type: 'GET', data: { countryId: selectedCountryId }, success: function(response) { $("#CityId").html(response); } }); }); 5. 在Controller的GetCityList Action,根据传入的countryId参数获取对应的城市数据,并将其转换为一个包含相应选项的字符串,然后将其返回给前端。例如: public ActionResult GetCityList(int countryId) { // 根据countryId获取对应的城市列表数据 var cityData = // 数据库操作或其他方式获取城市数据; // 将城市列表数据转换为一个包含选项的字符串 var cityOptions = ""; foreach (var city in cityData) { cityOptions += "<option value='" + city.CityId + "'>" + city.CityName + "</option>"; } return Content(cityOptions); } 通过以上步骤,就可以实现ASP.NET MVC的下拉列表联动效果。当第一个下拉列表的选项发生改变时,第二个下拉列表的选项会根据选择的进行更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值