对于LiteralControl控件的应用比较少,今天突然看到了,就弄个明白为好,所以总结出来,供大家一起学习。
第一,自己做测试
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server" id="head1">
<title >无标题页</title>
</head>
<body id="body1">
<form id="form1" runat="server">
<div id="div1">
<div id="div2">
</div>
</asp:Panel>
</div>
</form>
</body>
</html>
以上代码在读取最外层控件所有类型时:
System.Web.UI.LiteralControl-
System.Web.UI.HtmlControls.HtmlHead-head1
System.Web.UI.LiteralControl-
System.Web.UI.HtmlControls.HtmlForm-form1
System.Web.UI.LiteralControl-
可以看到有五个控件,其中两个服务器控件head和form。但是别的三个又是什么呢?
其实很简单:举个例子,如果页面上有一个服务器控件,ASP.net将会创建两个LiteralControl对象,分别代表这个控件之前和之后的静态内容。两个服务器控件,相应的就有三个LiteralControl对象。再看个例子
<html xmlns="http://www.w3.org/1999/xhtml">
html23232
<head runat="server" id="head1">
<title >无标题页</title>
</head>
/headerefefe
<body id="body1">
bogy343242
<form id="form1" runat="server">
<div id="div1">
<asp:Panel ID="Panel1" runat="server" Height="50px" Width="125px">
<div id="div2">
</div>
</asp:Panel>
</div>
</form>
这应该是form结束的地方
</body>
122233
</html>
5556665
显示外层的控件类型及其ID(LiteralControl显示其中的HTML文本)如下:
System.Web.UI.LiteralControl-
***text: 1231232321 html23232
System.Web.UI.HtmlControls.HtmlHead-head1
System.Web.UI.LiteralControl-
***text: /headerefefe bogy343242
System.Web.UI.HtmlControls.HtmlForm-form1
System.Web.UI.LiteralControl-
***text: 这应该是form结束的地方 122233 5556665
这个例子很明显的说明,在两个服务器控件之间的文本控件就是这样的内容。
第二,应用
LiteralControl 类
表示 HTML 元素、文本和 ASP.NET 页中不需要在服务器上处理的任何其他字符串。
ASP.NET 将所有不需要服务器端处理的 HTML 元素和可读文本编译为该类的实例。例如,在开始标记中不包含 runat="server" 属性/值对的 HTML 元素将被编译为 LiteralControl 对象。LiteralControl 对象不维护视图状态,因此必须针对每个请求重新创建 LiteralControl 对象的内容。
文本控件的行为与文本容纳器一样,这意味着可以从文本控件提取文本,并通过父服务器控件的 Controls 属性从父服务器控件的 ControlCollection 集合中移除文本控件。因此,当开发从 LiteralControl 类派生的自定义控件时,确保由控件自己执行任何所需的预处理步骤,而不是使用对 LiteralControl.Render 方法的调用来完成这些操作。通常,都会这样做以提高 Web 应用程序的响应时间。
可以以编程方式分别使用 ControlCollection.Add 或 ControlCollection.Remove 方法,从页或服务器控件添加或移除文本控件。
代码:
HtmlTableCell c = new HtmlTableCell();
c.Controls.Add( new LiteralControl("行 " + j.ToString() + ", 列 " + i.ToString()) );
r.Cells.Add(c);
这样做的目的就是为了提高web应用程序的响应时间,其实质跟写成c.InnerHTML=""是一样的,不过就是套用了面向对象的思想而已。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wjt132/archive/2009/12/10/4980284.aspx