做了一个table,往其中加了一些textbox,本来打算点击一个确定的button,就保存我输入在这些textbox中的值在数据库中,但是奇怪的很,我调试的时候发现本来table.rows.count有4行的,点击确定后,先执行pageload,再执行确定button函数,在pageload函数的起始处table.rows.count就变为0,导致根本无法用table.rows[i].cell[j].txt循环读出数据,大家帮帮忙啊。
table是用控件拖放的形式放在asp.net页面中的。

解决方案 »

  1.   

    在PageLoad里加上if(!IsPostBack){...}
      

  2.   

    同意  gshope(北京.Net)否则的话 你每次都初始化了页面。
      

  3.   

    楼上说的很正确,建议你用datalist或者datagrid
    模板技术支持下的这些控件操纵数据方便多了
      

  4.   

    用了if(!IsPostBack啊,我是在"添加"button中初始化table的(向table中加控件),然后就编辑table中的控件,按确定,他不先调用确定button的函数,先执行pageload,在pageload中的if(!IsPostBack)处table.rows.count就为0了,还没有开始判断页面是否是首次加载呢?为什么啊?
      

  5.   

    if(!IsPostBack)是pageload函数的第一行的,也就是说,只要进入了pageload,表就清0 了
      

  6.   

    你可以用 TextBox tb = (TextBox) table.FindControl("TextBox1")这种方式试试看。
      

  7.   

    为什么table的生存期在执行了pageload后就没有了,那我不是不能用按钮的方式获得table中输入的数据???
      

  8.   

    if (!IsPostBack)
    {
            //动态产生或装载控件
            //也许需要连接控件事件处理函数
           //加到父控件的Controls
    }里生成或装载了动态控件。当控件在客户端触发,postback到服务器端时,IsPostBack==true,这些控件没有被重新生成,怎么能触发事件?所以答案是,当你需要动态生成或装载控件时,应该在if (!IsPostBack)之外做。我问为什么想在if (!IsPostBack)之内做呢?回答是想只生成一次,跟在ASPX页面里一样<form id="form1" runat=server>
    <asp:Button id="Button1" runat="server" Text="Button1" OnClick="Button_Click"/>#%&%#&%^#&,你怎么会认为这个控件只生成一次呢?这些玩意也不是魔术,想生成一个Button对象,你需要用Button btn = new Button();需要触发它的Click事件,你需要用btn.Click += new EventHandler(YourHandler);即使象包含<asp:Button id="Button1" runat="server" Text="Button1" OnClick="Button_Click"/>的页面,它也是被转化成C#或VB文件,编译成assembly,然后再被执行的啊不信?加一个页面,TestControls.aspx:<%@ Page Debug="true" %>
    <%@ Import Namespace="System.Data"%>
    <%@ Import Namespace="System.Data.SqlClient"%><form id="form1" runat=server>
    <asp:Button id="Button1" runat="server" Text="Button1" OnClick="Button_Click"/>
    <asp:DataGrid id="DataGrid1" runat="server" AutoGenerateColumns="false" GridLines="Both">
    <Columns>
     <asp:TemplateColumn HeaderText="Name">
     <ItemTemplate><%# DataBinder.Eval(Container.DataItem,"Name")%></ItemTemplate>
     </asp:TemplateColumn>
    </Columns>
    </asp:DataGrid>
    </form>
    <script language="C#" runat="server">
    void Button_Click(Object sender, EventArgs e)
    {
      Button btn = (Button)sender;
      Response.Write(btn.Text + " is clicked<BR>");
    }void Page_Load(Object sender, EventArgs e)
    {
       
     Button btn = new Button();
     btn.ID = "Button2";
     btn.Text = "Button2";
     btn.Click += new EventHandler(Button_Click);
     form1.Controls.Add(btn);
       if (!IsPostBack)
       {
     SqlDataAdapter da = new SqlDataAdapter("select Name=au_fname + ' ' + au_lname from authors", "server=localhost;database=pubs;uid=sa;pwd=;");
     DataTable dt = new DataTable();
     da.Fill(dt);
     DataGrid1.DataSource = dt.DefaultView;
     DataGrid1.DataBind();
       }
     
    //}//这是故意的</script>把最后一个“}”注释掉,然后在浏览器里向你的服务器调用TestControls.aspx
      

  9.   

    codebehind中生成的table在postback后自动被复位的,要么用datagrid,要么用request取相应的值