摘要:《asp.net 2.0应用程序开发》一书中,第19页、第1.5.6小节的内容是关于asp.net 2.0服务器控件语法的描述,由于书中只是简单地进行了介绍,现将更多的内容补充说明如下:
1,asp.net 2.0服务器控件与的关系
asp.net 2.0服务器控件(html服务器控件和web服务器控件)是否必须需要放在
1,asp.net 2.0服务器控件与<form runat=server></form>的关系
asp.net 2.0服务器控件(html服务器控件和web服务器控件)是否必须需要放在<form runat=server></form>的标记之中,可以根据需要进行设置,大多数情况下,对于只用来进行界面显示的控件、并且不需要处理事件的控件,可以不放在<form runat=server></form>之间,对于大多数控件来说,是要在服务器端进行事件处理和获得某些返回值的,因此需要放在<form runat=server></form>之间。
2,如何进行控制
服务器控件在进行render、addattributestorender等的时候,会执行下面这句:
page page1 = this.page;
if (page1 != null)
{
page1.verifyrenderinginserverform(this);
}
page.verifyrenderinginserverform 方法 就是验证服务器控件是否需要在<form runat=server></form>的标记之中,如果不在这个标记之中,将会引发下面的异常。例如下面的代码:
<%@ page language="c#" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<script runat="server">
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>verifyrenderinginserverform</title>
</head>
<body>
<asp:textbox id="textbox1" runat="server"></asp:textbox>
<form id="form1" runat="server">
</form>
</body>
</html>
在浏览这样的页面时,将会引发异常:
类型“textbox”的控件“textbox1”必须放在具有 runat=server 的窗体标记内。
说明: 执行当前 web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: system.web.httpexception: 类型“textbox”的控件“textbox1”必须放在具有 runat=server 的窗体标记内。
这是因为,textbox控件在进行render的时候调用了page1.verifyrenderinginserverform(this);,因此,如果不放在<form runat=server></form>的标记之间,这个验证过程是通不过的。
但是,我们可以在代码中重载这个方法,以便是textbox控件可以放在<form runat=server></form>的标记之外,例如下面的代码:
<%@ page language="c#" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<script runat="server">
public override void verifyrenderinginserverform(control control)
{
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>verifyrenderinginserverform</title>
</head>
<body>
<asp:textbox id="textbox1" runat="server"></asp:textbox>
<form id="form1" runat="server">
</form>
</body>
</html>
浏览这样的页面就不会产生异常。
3,调整展现方式后,页面能否正常工作
msdn上解释page.verifyrenderinginserverform 方法时说:
如果回发或使用客户端脚本的服务器控件没有包含在 htmlform 服务器控件 (<form runat="server">) 标记中,它们将无法正常工作。这些控件可以在呈现时调用该方法,以在它们没有包含在 htmlform 控件中时提供明确的错误信息。
是的,虽然下面的代码可以正常显示,但一旦单击“提交”按钮,服务器端将得不到输入的值,页不能保存状态了。
<%@ page language="c#" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<script runat="server">
public override void verifyrenderinginserverform(control control)
{
}
protected void button1_click(object sender, eventargs e)
{
response.write("<li>textbox1.text = " + textbox1.text);
response.write("<li>request.params = " + request.params[textbox1.uniqueid]);
}
protected void page_load(object sender, eventargs e)
{
response.write("<li>textbox1.text = " + textbox1.text);
response.write("<li>request.params = " + request.params[textbox1.uniqueid]);
if (!ispostback)
{
textbox1.text = "《asp.net2.0应用开发技术》";
}
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>verifyrenderinginserverform</title>
</head>
<body>
<asp:textbox id="textbox1" runat="server" width="600px"></asp:textbox>
<form id="form1" runat="server">
<asp:button id="button1" runat="server" onclick="button1_click"
text="提交" />
</form>
</body>
</html>
因此,在一般情况下,不要将服务器控件移到<form runat=server></form>的标记之外
4,如何强制将服务器控件放入<form runat=server></form>的标记之间
有些服务器控件可以不放在<form runat=server></form>的标记之间,如label控件,但如果需要强制将它放<form runat=server></form>的标记之间,可以使用下面的方法:
protected void label1_prerender(object sender, eventargs e)
{
this.verifyrenderinginserverform(label1);
}
5,百害而无一益?
有时候,页面上需要放置多个form表单(虽然只放置一个<form runat=server></form>的表单也能实现),将表单控件放在<form runat=server></form>标记之外,将非常方便使用,这在以前的asp页面中很常见,现在在aspx中也可义实现。下面的页面,既利用了服务器控件的方便性,也逃脱出了类型“textbox”的控件“textbox1”必须放在具有 runat=server 的窗体标记内的限制。例如:
<%@ page language="c#" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<script runat="server">
protected void button1_click(object sender, eventargs e)
{
response.write("<li>textbox1.text = " + textbox1.text);
response.write("<li>request.params = " + request.params[textbox1.uniqueid]);
}
protected void page_load(object sender, eventargs e)
{
keywords.text = "《asp.net2.0应用开发技术》";
response.write("<li>textbox1.text = " + textbox1.text);
response.write("<li>request.params = " + request.params[textbox1.uniqueid]);
if (!ispostback)
{
textbox1.text = "《asp.net2.0应用开发技术》";
}
}
public override void verifyrenderinginserverform(control control)
{
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>verifyrenderinginserverform</title>
</head>
<body>
<form method="post" action="searchdoc.aspx">
关键字:<asp:textbox id="keywords" runat="server"></asp:textbox>
<asp:button id="button2" runat="server" text="搜索" />
</form>
<form id="form1" runat="server">
<asp:textbox id="textbox1" runat="server" width="600px"></asp:textbox>
<asp:button id="button1" runat="server" onclick="button1_click"
text="提交" />
</form>
</body>
</html>
在searchdoc.aspx页面,使用request.form即可获得输入的关键字。
相关文章推荐
智能手机建站的优点是什么?网站页面布局有哪些关键点? 2022-01-10
2022年中国云计算面临的问题及发展前景预测分析2021-12-28
绿色智能基础设施连接可持续未来-IDCC2021万国数据第一代Smart DC发布会议程揭晓2021-12-27
阿里云:早期未意识到Apache log4j2漏洞情况的严重性 将强化漏洞管理2021-12-27
云计算开发:Python3-replace()方法详解2021-12-27