如何发送复选框的选中值?我想将复选框值发送到控制器并保存数据库中的更改

时间:2015-05-07 08:01:32

标签: asp.net-mvc-4 checkbox ef-database-first

如何在控制器mvc 4中获取复选框值?我想将复选框值发送到控制器并保存数据库中的更改。我正在使用Entity Framework 4.5和MVC4 databasefirst。

1 个答案:

答案 0 :(得分:0)

首先创建视图模型

 public class UnitVM 
    {
    public List<Unit> UnitObj { get; set; }
}

public class Unit
    {
    public int Id { get; set; } 
    public string RoomNo { get; set; }
    public bool CheckedStatus { get; set; }
}

然后在控制器中,创建“HttpGet”动作以绑定checkboxlist。

别忘了添加

使用BootMvcApplication3.Models;

使用System.Text;

[HttpGet]
    public ActionResult Med()
    {
        UnitVM obj = new UnitVM(); // Create object of viewmodel
        obj.UnitObj = BindUnits(); // function to bind checkboxlist values
        return View(obj);
    }

    public List<Unit> BindUnits()
    {
        List<Unit> obj = new List<Unit>();
        var trverse = dbContext.ALFUnits.Where(x => x.UNITSiteCode.Equals("AZA"));

        foreach (var i in trverse)
        {
            obj.Add(new Unit { Id = i.Id, RoomNo = i.RoomNo });
        }

        return obj;
    }

[HttpPost]
    public ActionResult Med(UnitVM obj)
    {

        StringBuilder sb = new StringBuilder();

        foreach (var item in obj.UnitObj)
        {
            if (item.CheckedStatus == true)
            {
                sb.Append(item.RoomNo + ", ").AppendLine();
            }
        }

        ALFMedcartMaster add = new ALFMedcartMaster();

        add.Room = sb.ToString(); //Store checked Room nos. in "101,102,103" this format

        dbContext.ALFMedcartMasters.Add(add);
        dbContext.SaveChanges();
        return View();
    }

在视图中

@model BootMvcApplication3.Models.UnitVM

for (int i = 0; i < Model.UnitObj.Count; i++)
        {
                    @Html.CheckBoxFor(m => Model.UnitObj[i].CheckedStatus)
                    @Model.UnitObj[i].RoomNo
                    @Html.HiddenFor(m => Model.UnitObj[i].Id)
                    @Html.HiddenFor(m => Model.UnitObj[i].RoomNo)

        }

<input type="submit" value="Update" />

在视图中,需要“CheckedStatus”才能保​​存真实&amp;虚假价值 和“@ Model.UnitObj [i] .RoomNo”用于显示实际房间号。