如何通过Table Rows进行操作

时间:2013-07-18 17:46:41

标签: c# asp.net

我需要改进一个表

我使用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'

2 个答案:

答案 0 :(得分:6)

您需要引用表的Rows属性。

 foreach (TableRow row in mytable.Rows)

答案 1 :(得分:3)

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

以下是显示其部分用法的链接:http://www.dotnetspider.com/resources/44926-GridView-Edit-Cancel-Update-Delete-ASP.net.aspx