当前位置: 移动技术网 > IT编程>开发语言>.net > ASP.NET中Literal与Label控件的区别

ASP.NET中Literal与Label控件的区别

2017年12月12日  | 移动技术网IT编程  | 我要评论

一、方案和背景

literal 控件表示用于向页面添加内容的几个选项之一。对于静态内容,无需使用容器,可以将标记作为 html 直接添加到页面中。但是,如果要动态添加内容,则必须将内容添加到容器中。典型的容器有 label 控件、literal 控件、panel 控件和 placeholder 控件。

literal 控件与 label 控件的区别在于 literal 控件不向文本中添加任何 html 元素。(label 控件呈现一个 span 元素。)因此,literal 控件不支持包括位置属性在内的任何样式属性。但是,literal 控件允许指定是否对内容进行编码。

panel 和 placeholder 控件呈现为 div 元素,这将在页面中创建离散块,与 label 和 literal 控件进行内嵌呈现的方式不同。

通常情况下,当希望文本和控件直接呈现在页面中而不使用任何附加标记时,可使用 literal 控件。

在 literal 控件中编码内容

literal 控件支持 mode 属性,该属性用于指定控件对您所添加的标记的处理方式。可以将 mode 属性设置为以下值:

·transform. 将对添加到控件中的任何标记进行转换,以适应请求浏览器的协议。如果向使用 html 外的其他协议的移动设备呈现内容,此设置非常有用。

·passthrough. 添加到控件中的任何标记都将按原样呈现在浏览器中。

·encode. 将使用 htmlencode 方法对添加到控件中的任何标记进行编码,这会将 html 编码转换为其文本表示形式。例如,<b> 标记将呈现为 <b>。当希望浏览器显示而不解释标记时,编码将很有用。编码对于安全也很有用,有助于防止在浏览器中执行恶意标记。显示来自不受信任的源的字符串时推荐使用此设置。

二、literal和label到底有什么区别

  label在经服务器处理后转换成客户端网页时候使用html的<span>标记为住控件,而literal则是什么标记都不带 。

  例如:<span id="label1">label</span>(label的客户端代码)
        <b>移动技术网</b>(literal的客户端代码)

  literal不可以运用样式。定位布局比较麻烦。在您要以编程方式设置文本而不添加额外的 html 标记时,可以向页面添加 literal web 服务器控件。在要向页面动态添加文本而不添加任何不属于该动态文本的元素时,literal 控件非常有用。例如,您可以使用literal 控件来显示从文件或流中读取的 html。如果要显示静态文本,则可以使用 html 呈现它;不需要 literal 控件。只有在需要以编程方式呈现文本时才使用 literal 控件。

三、如何:向 web 窗体页添加 literal web 服务器控件

  在您要以编程方式设置文本而不添加额外的 html 标记时,可以向 web 窗体页添加 literal web 服务器控件。在要向页面动态添加文本而不添加任何不属于该动态文本的元素时,literal 控件是一种很有用的方式。例如,您可以使用 literal 控件来显示您从一个文件或者流中读取的 html。

  说明: 如果想显示静态文本,可以使用 html 呈现它;不需要 literal 控件。只有在需要动态更改服务器代码中的内容时才使用 literal 控件。

  1、从工具箱的“标准”选项卡中,将 literal 控件拖动到页面上。

  2、或者,在“属性”窗口的“行为”类别下,将 mode 属性设置为 transform、passthrough 或者 encode。mode 属性指定该控件如何处理向其添加的任何标记。下面的示例显示一个简单网页,该页在运行时显示标题新闻。该页的主体(包括 literal 控件)类似于下面的代码。

复制代码 代码如下:

<body>
  <form runat="server">
    <h1><asp:literal id="headline" runat=server mode="passthrough"/></h1>
  </form>
</body>

  3、将代码添加到页面上以在运行时设置控件的 text 属性。

下面的示例显示如何以编程方式设置 literal 控件的文本和编码。该页包含一组单选按钮,允许用户在编码文本和传递文本之间选择。

说明: 如果您正将 text 属性设置为来自不受信任源的文本,则要将控件的 mode 属性设置为 encode,这样标记才不会形成可执行标记。

复制代码 代码如下:

<%@ page language="c#" %>
<script runat="server">
    protected void page_load(object sender, eventargs e)
    {
        literal1.text = "this <b>text</b> is inserted dynamically.";
        if (radioencode.checked == true)
        {
            literal1.mode = literalmode.encode;
        }
        if(radiopassthrough.checked == true)
        {
            literal1.mode = literalmode.passthrough;
        }
    }
</script>
 
<html>
<head runat="server"></head>
<body>
    <form id="form1" runat="server">
    <div>
        <br />
        <asp:radiobutton
            id="radioencode"
            runat="server"
            groupname="literalmode"
            checked="true"
            text="encode"
            autopostback="true" />
        <br />
        <asp:radiobutton
            id="radiopassthrough"
            runat="server"
            groupname="literalmode"
            text="passthrough"
            autopostback="true" />
        <br />
        <br />
        <asp:literal id="literal1" runat="server"></asp:literal> </div>
    </form>
</body>
</html>

四、literal 类

在网页上保留显示静态文本的位置。

  使用 system.web.ui.webcontrols.literal 控件在网页上保留显示文本的位置。literal 控件与 label 控件类似,但 literal 控件不允许对所显示的文本应用样式。可以通过设置 text 属性,以编程方式控制在控件中显示的文本。

  警告: 此控件可用来显示用户输入,而该输入可能包含恶意的客户端脚本。在应用程序中显示从客户端发送来的任何信息之前,请检查它们是否包含可执行脚本、sql 语句或其他代码。asp.net 提供输入请求验证功能以阻止用户输入中的脚本和 html。还提供验证服务器控件以判断用户输入。


下面的示例说明如何使用 literal 控件显示静态文本。

  说明: 下面的示例使用单文件代码模型,如果将它直接复制到代码隐藏文件中,则它可能无法正常工作。此代码示例必须被复制到具有 .aspx 扩展名的空文本文件中。

复制代码 代码如下:

<%@ page language="c#" autoeventwireup="true" %>
 
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "">
 
<html>
<head>
    <title>literal example</title>
<script runat="server">
      void buttonclick(object sender, eventargs e)
      {
         literal1.text="welcome to asp.net!!";
      }
   </script>
</head>
<body>
   <form id="form1" runat="server">
      <h3>literal example</h3>
      <asp:literal id="literal1"
           text="hello world!!"
           runat="server"/>
      <br /><br />
      <asp:button id="button1"
           text="change literal text"
           onclick="buttonclick"
           runat="server"/>
   </form>
</body>
</html>

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网