Asp.Net MVC4中的CheckBoxList

时间:2012-11-16 14:23:21

标签: c# asp.net asp.net-mvc checkbox asp.net-mvc-4

我正在尝试在View中实现CheckBoxList,并在List中获取所选复选框值列表。

我尝试了此link中的示例,但我无法获取所选的选中列表项。

我的观点

@foreach (var item in Model)
{
    <tr>
        <td align="center" class="Text_nocolor singleCheckbox">
            <input type="checkbox" class="checkbox" value="@item.ProductID" name="selectedObjects"/>
            @Html.HiddenFor(modelItem => item.ProductName)
        </td>
        <td align="center" class="Text_nocolor" id="myimage">
            <img src="@Url.Content(item.Imageurl)" width="40px" height="40px"  title="@item.ProductName" alt="Product"  class="myimage" style="border-style:none;"/>
        </td>
        <td align="left" class="Text_nocolor">
            @Html.DisplayFor(modelItem => item.ProductName)
        </td>
    </tr>
}
@Html.ActionLink(" ", "Checkout", new { controller = "Checkout", UserID = Request.QueryString["UserID"], Partnerid = Request.QueryString["Partnerid"] }, new { @class = "btnCheckout" })

控制器代码(索引):

SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["DBConnection"].ConnectionString);
public IList<CartModel> GetCartDetails(string id, string partnerid)
{
    List<CartModel> CartDetails = new List<CartModel>();
    {
        con.Open();
        SqlCommand cmd = new SqlCommand("select * from tablename where [User ID]='" + id + "' and [Partner ID]='" + partnerid + "'", con);
        SqlDataAdapter da = new SqlDataAdapter(cmd);
        DataTable dt = new DataTable();
        da.Fill(dt);
        if (dt.Rows.Count > 0)
        {
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                CartModel cartInfo = new CartModel();
                cartInfo.ProductName = dt.Rows[i]["Product Name"].ToString();
                cartInfo.Imageurl = "~/Handler.ashx?Pid=" + dt.Rows[i]["Product ID"].ToString() + "&Imgid=1&Partnerid=" + partnerid;
                CartDetails.Add(cartInfo);
            }
        }
        con.Close();
    }
    return CartDetails;
}

public ActionResult Index()
{
    id = Request.QueryString["UserID"];
    partnerid = Request.QueryString["Partnerid"];
    IList<CartModel> objshop = new List<CartModel>();
    objshop = GetCartDetails(id, partnerid);
    ViewBag.Categories = objshop.ToList();
    return View(objshop.ToList());
}

public ActionResult Checkout(string id, string partnerid, int[] categories)
{
    string id = Request.QueryString["UserID"];
    string partnerid = Request.QueryString["Partnerid"];
    //How to get the selected checked list items as a list.
    return View();
}

有什么建议吗?

1 个答案:

答案 0 :(得分:0)

最后,我通过Webgrid获取了一个复选框列表。

参考此博客 http://weblogs.asp.net/imranbaloch/archive/2011/09/13/webgrid-helper-with-check-all-checkboxes.aspx

  @grid.GetHtmlWithSelectAllCheckBox(tableStyle: "webGrid",
            headerStyle: "header",
            checkBoxValue: "ProductID",
            columns: grid.Columns(
            grid.Column(columnName: "", format: @<text><img src="@Url.Content(item.Imageurl)" class="image" alt="Image "/></text>, style: "txtalignleft"),
            grid.Column(columnName: "ProductName", style: "txtalignleft"),
            grid.Column(columnName: "Quantity", style: "txtcenter"),
            grid.Column("Edit", " ", style: "txtalignleft", format: @<a href="@Url.Action("Index", "Cart", new { UserID = Request.QueryString["UserID"], partnerid = Request.QueryString["Partnerid"] })"><img
                alt="edititem" style="vertical-align: middle; text-align: justify; border-style: none;"
                height="17px" src="../../Images/edit.png" title="Edit" id="imgEdit" /></a>),
            grid.Column(columnName: "Rate", style: "txtalign"),
            grid.Column(columnName: "Price", style: "txtalign")
      ))