如何在 C# 中使用 foreach 获取复选框列表中的选定项的值 ASP.NET

本文关键字:NET 列表 ASP 获取 foreach 复选框 | 更新日期: 2023-09-27 18:32:07

我有一个这样的复选框列表:

<asp:CheckBoxList ID="CBLGold" runat="server" CssClass="cbl">
    <asp:ListItem Value="TGJU"> TG </asp:ListItem>
    <asp:ListItem Value="GOLDOZ"> Gold </asp:ListItem>
    <asp:ListItem Value="SILVEROZ"> Silver </asp:ListItem>
    <asp:ListItem Value="NERKH"> NE </asp:ListItem>
    <asp:ListItem Value="TALA"> Tala </asp:ListItem>
    <asp:ListItem Value="YARAN"> Sekeh </asp:ListItem>
</asp:CheckBoxList>

现在,我想使用foreach从此CheckBoxList中获取所选项目的值,并将这些值放入列表中。

如何在 C# 中使用 foreach 获取复选框列表中的选定项的值 ASP.NET

请注意,我更喜欢代码简短。

List<ListItem> selected = CBLGold.Items.Cast<ListItem>()
    .Where(li => li.Selected)
    .ToList();

或一个简单的foreach

List<ListItem> selected = new List<ListItem>();
foreach (ListItem item in CBLGold.Items)
    if (item.Selected) selected.Add(item);

如果您只想要ListItem.Value

List<string> selectedValues = CBLGold.Items.Cast<ListItem>()
   .Where(li => li.Selected)
   .Select(li => li.Value)
   .ToList();
foreach (ListItem item in CBLGold.Items)
{
    if (item.Selected)
    {
        string selectedValue = item.Value;
    }
}

下午好,您始终可以使用一点 LINQ 来获取选定的列表项,然后对结果执行所需的操作:

var selected = CBLGold.Items.Cast<ListItem>().Where(x => x.Selected);
// work with selected...

根据此处的建议,我添加了一个扩展方法,以使用 LINQ 为任何类型返回所选项目的列表 继承自 System.Web.UI.WebControls.ListControl .

每个ListControl对象都有一个类型 ListItemCollectionItems 属性。 ListItemCollection公开了ListItems的集合,每个都有一个Selected属性。

C 夏普:

public static IEnumerable<ListItem> GetSelectedItems(this ListControl checkBoxList)
{
    return from ListItem li in checkBoxList.Items where li.Selected select li;
}

Visual Basic:

<Extension()> _
Public Function GetSelectedItems(ByVal checkBoxList As ListControl) As IEnumerable(Of ListItem)
    Return From li As ListItem In checkBoxList.Items Where li.Selected
End Function

然后,只需在任一语言中使用这样的语言:

myCheckBoxList.GetSelectedItems()
List<string> values =new list<string>();
foreach(ListItem Item in ChkList.Item)
{
    if(Item.Selected)
    values.Add(item.Value);
}

要补充@Tim Schmelter,取回List<int>

List<string> selectedValues = CBLGold.Items.Cast<ListItem>()
   .Where(li => li.Selected)
   .Select(li => li.Value)
   .Select(int.Parse)
   .ToList();

如果你有一个数据绑定checklistbox则无法获取item(j).Selected,因为控件没有选定的属性。如果您清除选择,即加载时,那么显然它现在理解item(j).selected.

如果您想将

所选值存储在由,分隔的单列中,那么您可以使用以下方法

string selectedItems = String.Join(",", CBLGold.Items.OfType<ListItem>().Where(r => r.Selected).Select(r => r.Value));

如果要存储文本而不是值,则将 r.Value 更改为 r.Text

string s= string.Empty
for (int i = 0; i < Chkboxlist.Items.Count; i++)
{
    if (Chkboxlist.Items[i].Selected)
    {
        s+= Chkboxlist.Items[i].Value + ";"; 
    }
}

在我的代码隐藏中,我在Page_Load事件中从sql db创建了一个复选框列表,在我的button_click事件中,我从复选框列表中获取了所有值等。

因此,当我选中一些复选框然后单击我的按钮时,发生的第一件事是我的page_load事件重新创建了复选框列表,因此在运行我的 get 复选框值时没有选中任何框......我错过了在page_load事件中添加 if (!this.IsPostBack)

protected void Page_Load(object sender, EventArgs e)
{
   if (!this.IsPostBack)
   {
      // db query and create checkboxlist and other
      SqlConnection dbConn = new SqlConnection(WebConfigurationManager.ConnectionStrings["ConnString"].ConnectionString);
      string query;
      try
      {
        query = "SELECT [name], [mail] FROM [users]";
        dbConn.Open();
        SqlDataAdapter da = new SqlDataAdapter(query, dbConn);
        DataSet ds = new DataSet();
        da.Fill(ds);
        if (ds.Tables[0].Rows.Count != 0)
        {
          checkboxlist1.DataSource = ds;
          checkboxlist1.DataTextField = "name";
          checkboxlist1.DataValueField = "mail";
          checkboxlist1.DataBind();
        }
        else
        {
          Response.Write("No Results found");
        }
       }
       catch (Exception ex)
       {
          Response.Write("<br>" + ex);
       }
       finally
       {
          dbConn.Close();
       }
   }
}
protected void btnSend_Click(object sender, EventArgs e)
 {
   string strChkBox = string.Empty;
   foreach (ListItem li in checkboxlist1.Value)
    {
      if (li.Selected == true)
       {
         strChkBox += li.Value + "; ";    
         // use only   strChkBox += li + ", ";   if you want the name of each checkbox checked rather then it's value.
       }
    }
   Response.Write(strChkBox);
 }

输出正如预期的那样,一个分号分隔的列表供我在邮件发送函数中使用:

    bill@contoso.com; jeff@corp.inc; sam@dot.net
一个小

问题的长答案。请注意,我远非这方面的专家,并且知道有比这更好的解决方案,但它可能对某些人有所帮助。

我喜欢使用这个简单的方法来获取选定的值并将它们连接到一个字符串中

private string JoinCBLSelectedValues(CheckBoxList cbl, string separator = "")
{
    return string.Join(separator, cbl.Items.Cast<ListItem>().Where(li => li.Selected).ToList());
}