nbsp; mylinkbutton.Click+=new EventHandler(Say_Hello); thisform.Controls.Add(mylinkbutton); }
public void Say_Hello(Object sender,EventArgs e) { Response.Write("Hello,World!"); }
public void Say_Goodbye(Object sender,EventArgs e) { Response.Write("Goodbye,World!"); }
public void AddButton(Object sender,EventArgs e) { thisform.Controls.Add(new LiteralControl(" ")); LinkButton mylinkbutton=new LinkButton(); mylinkbutton.Text="say Goodbye"; mylinkbutton.ID="goodbye"; mylinkbutton.Click+=new EventHandler(Say_Goodbye); thisform.Controls.Add(mylinkbutton);
}
</script> <body> <form id="thisform" runat="server"> <asp:linkbutton Text="Add Button" OnClick="AddButton" runat="server"/>
</form> </body> </html>
各位可以尝试运行一下,看有什么问题。
最后,是dragontt让我知道了其中的玄机。原来,Http是一个无状态的协议,每一次同服务器的交互都是作为新的请求来处理。每个页面都是重新生成的,然后根据客户端保存并传递来得ViewState使得服务器端生成的新页面与客户端当前页面的状态相同,接着服务器端会根据客户端的请求,来完成任务。所以,当我点击了Add a new record按钮之后,增加了一个新的LinkButton,但是服务器端新生成的页面并不会记住这个LinkButton,也就不会去执行相应的代码了。
解决办法是:在AddButton中增加代码:ViewState["test"]=1;
在Page_Load中增加代码:if (ViewState["test"]!=null)
Say_Goodbye ( sender, e ) ;
通过ViewState的使用,使得服务器端控件的状态得以保持。与这个小程序相对应的,第一个例子的问题也是可以通过这种办法去解决的。
PS:随着了解的进一步深入,ViewState是一个需要花大力气去研究的东西。给朋友们留个问题,虽然通过添加两行代码把问题解决了,可是又有新的问题出现了。大家可以尝试一下,当你点击了Add Button之后,出现了另外一个say Goodbye的LinkButton,点击它,正如我们想象一样,"Goodbye World!"出现在屏幕上。但是--如果你不点击动态生成的say Goodbye 的LinkButton,而去点击say Hello的LinkButton,会出现什么呢?结果是出人意料的,那该怎么解决呢?让我下次再续。
上一页 [1] [2] |