78

我有一个这样的 CheckBoxList:

<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 中获取所选项目的值,并将这些值放入列表中。

4

11 回答 11

200

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

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();
于 2013-09-20T19:12:43.223 回答
13
foreach (ListItem item in CBLGold.Items)
{
    if (item.Selected)
    {
        string selectedValue = item.Value;
    }
}
于 2013-10-18T04:11:14.423 回答
10

下午好,您总是可以使用一点 LINQ 来获取选定的列表项,然后对结果执行您想要的操作:

var selected = CBLGold.Items.Cast<ListItem>().Where(x => x.Selected);
// work with selected...
于 2013-09-20T19:15:00.663 回答
2

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

每个ListControl对象都有一个Itemstype 的属性ListItemCollectionListItemCollection公开 的集合ListItems,每个集合都有一个Selected属性。

C夏普:

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

视觉基础:

<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()
于 2014-02-20T15:53:31.097 回答
1
List<string> values =new list<string>();
foreach(ListItem Item in ChkList.Item)
{
    if(Item.Selected)
    values.Add(item.Value);
}
于 2016-02-03T08:17:56.347 回答
1

为了补充@Tim Schmelter,List<int>取而代之的是,

List<string> selectedValues = CBLGold.Items.Cast<ListItem>()
   .Where(li => li.Selected)
   .Select(li => li.Value)
   .Select(int.Parse)
   .ToList();
于 2017-12-11T06:32:55.717 回答
1

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

于 2020-08-18T22:47:58.010 回答
1

万一您想将选定的值存储在单独的单列中,,您可以使用以下方法

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

如果您想存储 Text 而不是值,则将 r.Value 更改为 r.Text

于 2021-01-03T05:29:51.203 回答
0
string s= string.Empty

for (int i = 0; i < Chkboxlist.Items.Count; i++)

{

    if (Chkboxlist.Items[i].Selected)
    {
        s+= Chkboxlist.Items[i].Value + ";"; 
    }

}
于 2014-12-27T12:56:11.257 回答
0

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

因此,当我检查了一些复选框然后单击我的按钮时,发生的第一件事是我的 page_load 事件重新创建了复选框列表,因此在运行我的获取复选框值时没有检查任何框...我错过了添加 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

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

于 2016-05-11T22:34:40.877 回答
0

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

private string JoinCBLSelectedValues(CheckBoxList cbl, string separator = "")
{
    return string.Join(separator, cbl.Items.Cast<ListItem>().Where(li => li.Selected).ToList());
}
于 2020-11-05T10:03:48.813 回答