如何通过TableRows进行foreach

本文关键字:foreach 进行 TableRows 何通过 | 更新日期: 2023-09-27 18:23:53

我需要改进一个表

我使用C#将行添加到此表中。

  foreach (var item in items)
            {
                TableRow row = new TableRow();
                TableCell cell = new TableCell();
                LinkButton lb2 = new LinkButton();
                CheckBox chk = new CheckBox();
                chk.CssClass = "chkBox";
                lb2.CommandArgument = item.id.ToString();
                lb2.Text = item.cat_name;
                lb2.ID = "lb" + item.id.ToString();
                lb2.Click += new EventHandler(lb_Click);
                Label lbl = new Label();
                lbl.Text = "    ";
                LinkButton lb3 = new LinkButton();
                lb3.CommandArgument = item.id.ToString();
                lb3.ID = "lb3" + item.id.ToString();
                lb3.Text = "Edit/Delete";
                lb3.Click += new EventHandler(lb2_Click);
                cell.Controls.Add(chk);
                cell.Controls.Add(lb2);
                cell.Controls.Add(lbl);
                cell.Controls.Add(lb3);
                row.Cells.Add(cell);
                tblitems.Rows.Add(row);
            }

现在我需要编写另一个方法,允许我在表中选中哪些复选框。这样我就可以删除选中的行。

这就是我所拥有的。

protected void DeleteAll_Click(object sender, EventArgs e)
    {
        var mytable = (Table)FindControl("tblitems");
        foreach (TableRow row in mytable)
        {
            var myChkBox = (CheckBox)mytable.FindControl("chkBox");
            var myhiddenfield = (HiddenField)mytable.FindControl("hiddenID");
            if (myChkBox.Checked)
            {
                //Delete record 
              Response.Write("Record" + myhiddenfield.Value + "Has been deleted");
            }
        }
    }

我出错了foreach statement cannot operate on variables of type 'System.Web.UI.WebControls.Table' because 'System.Web.UI.WebControls.Table' does not contain a public definition for 'GetEnumerator'

如何通过TableRows进行foreach

您需要引用表的Rows属性。

 foreach (TableRow row in mytable.Rows)

Bill的回答将修复您的代码,但您可能需要考虑使用Repeater或GridView来创建与数据源关联的表格数据。GridView已经支持一些基本的编辑/删除等。

这里有一个链接,显示了它的一些用法:http://www.dotnetspider.com/resources/44926-GridView-Edit-Cancel-Update-Delete-ASP.net.aspx