asp.net mvc中DropDownList,CheckBox,RadioButton

在实体User中建立selectlist的属性

public SelectList CheckBoxList { get; set; }
public SelectList RadioButtonList { get; set; }

新建一个A实体做为键值操作

    public class A
    {
        public int value{get;set;}
        public string text{get;set;}
    }

 调用数据

 protected SelectList CheckBoxList(object defaultvalue)
        {
            List<A> obja = new List<A>()
            {
                new A(){text="第一",value=1},
                new A(){text="第二",value=2},
                new A(){text="第三",value=3},
                new A(){text="第四",value=4},
            };
            return new SelectList(obja, "value", "text", defaultvalue);
        }
        protected SelectList RadioButtonList(object defaultvalue)
        {
            List<A> obja = new List<A>()
            {
                new A(){text="第一",value=1},
                new A(){text="第二",value=2},
                new A(){text="第三",value=3},
                new A(){text="第四",value=4},
            };
            return new SelectList(obja, "value", "text", defaultvalue);
        }

 action中初始化

   public ActionResult Index()
        {
            
            User objuser = new User()
            {
                Email = "objectboy@msn.com",
                Name = "objectboy",
                CheckBoxList = CheckBoxList(3), //调用
                RadioButtonList=RadioButtonList(2) //调用
            };
            return View(objuser);
        }

 页面调用

@model MvcApplication2.Models.User

.............



  <div class="editor-field">
            @Html.DropDownList("SLlist1", Model.CheckBoxList,"请选择")
        </div>
        <div class="editor-field">
            @foreach (SelectListItem item in Model.CheckBoxList)
            {
                @Html.CheckBox("SomeParas", item.Selected, new { value = item.Value })
                @Html.Label(item.Text);
            }
        </div>
        <div class="editor-field">
            @foreach (SelectListItem item in Model.RadioButtonList)
            {
                @Html.RadioButton("dd", item.Value, item.Selected);
                @Html.Label(item.Text);

            }

注意:控件的名字不能与实体中属性名相同,要不无法初始化

仅限于个人学习,有好方法劳烦指教,谢谢...

转载于:https://www.cnblogs.com/objectboy/archive/2013/05/10/3070895.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值