ASP.NET中的asp:label和asp:literal

一、方案

Literal 最常用于向页面中动态添加内容。

二、背景

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>
标记将呈现为
&lt;b&gt;。当希望浏览器显示而不解释标记时,编码将很有用。编码对于安全也很有用,有助于防止在浏览器中执行恶意标记。显示来自不受信任的源的字符串时推荐使用此设置。

三、如何:向 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>

</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>&nbsp;</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"

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<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>

ASP.NET中的asp:label和asp:literal,码迷,mamicode.com

时间: 2024-08-03 13:31:30

ASP.NET中的asp:label和asp:literal的相关文章

使用ASP.NET中的Chart.js在ASP.NETVisual数据中使用Chart.js的可视化数据

Download Chart.js你可以Chart.js从这封信中:https://github.com/chartjs/Chart.js/releases 使用VisualStudio创建新的ASP.NET项目并复制Chart.js在上一步中下载到root项目. 创建一个名为"Home.aspx"并添加如下代码行: 藏   复制码 <%@ Page Language="C#" AutoEventWireup="true" CodeBehi

Asp.net中Postback及Callback

我们知道,在默认的情况下,当我们点击Asp.net Page中的一个服务器Button时(默认其实是Submit Form),会导致Page被Recreated,这个过程我们称之为Postback,它是Page生命周期的一个阶段.我们将从以下几个方面来简单谈谈Asp.net中的Postback: 为什么使用Postback Postback工作过程 为什么使用Callback Callback工作过程 Postback与Callback的区别 参考资料 1.为什么使用Postback 当我们每次

温故而知新:Asp.Net中如何正确使用Session

原文链接作者:菩提树下的杨过出处:http://yjmyzz.cnblogs.com Asp.Net中的Session要比Asp中的Session灵活和强大很多,同时也复杂很多:看到有一些Asp.Net开发人员报怨说Session不稳定,莫名其妙的丢失,其实这正是Asp.Net改进的地方之一. 我们知道Session与Cookie最大的区别在于:Cookie信息全部存放于客户端,Session则只是将一个ID存放在客户端做为与服务端验证的标记,而真正的数据都是放在服务端的内存之中的. 在传统we

asp.net中Literal与label的区别

摘自:http://www.cnblogs.com/Fskjb/archive/2010/03/19/1690233.html 一.方案 Literal 最常用于向页面中动态添加内容. 二.背景 Literal 控件表示用于向页面添加内容的几个选项之一.对于静态内容,无需使用容器,可以将标记作为 HTML 直接添加到页面中.但是,如果要动态添加内容,则必须将内容添加到容器中.典型的容器有 Label 控件.Literal 控件.Panel 控件和 PlaceHolder 控件. Literal

ASP.NET中的&lt;%%&gt;介绍

一.主要用于ASP.NET前台绑定用的最多: <%#Eval("")%> <%#Bind("")%> <%=变量%> 1.<%#Eval("数据列")%>主要用于需要进行更改的数据列 如:需要将<%Eval("性别")%>=1:将1转换成女. 首先在.CS文件中定义一个方法: 1 public object ChangeSex(object obj) 2 { 3 if

ASP.NET中进行消息处理(MSMQ) 二

在我上一篇文章<ASP.NET中进行消息处理(MSMQ)一>里对MSMQ做了个通俗的介绍,最后以发送普通文本消息和复杂的对象消息为例介绍了消息队列的使用. 本文在此基础上继续介绍MSMQ的相关知识点,最后还是通过一个示例程序来分析MSMQ在实际项目开发中的应用. 建议:如果你对MSMQ不够了解,在你阅读本文前请先阅读第一部分:<ASP.NET中进行消息处理(MSMQ)一>. 一.消息传递的优先级      在MSMQ中消息在队列里传输是分有优先级的,这里我就以实例的形式介绍下关于优

ASP.NET中利用Application和Session统计在线人数、历史访问量

先来简单说一下ASP.NET中的Application和Session 下图是我们非常熟悉的Web应用程序的结构: 在这张图中,Web服务器中运行的Web应用程序就是我们所说的Application,每个客户端与Web服务器之间建立的连接就可以看做是一个Session.比如现在服务器端运行的是一个论坛系统,那么现在这个正运行在服务器端的论坛系统的软件就可以看做Application,而每个在线的用户与之建立的连接就相当于一个Session. 那么很容易就会理解,Application是共享的,相

asp.net中listview下嵌套gridview

最近在上软件工程实践课程,想做一个类似于QQ空间或者朋友圈一样的效果.即显示所有好友发送的动态以及动态下回复的信息. 自己YY了一种方法,一开始以为不能达到效果,研究了2个小时终于实现了,感觉效果还是很棒棒的,拿来分享一下.神犇请绕道吧~~ listview可以自己排版布局,我们用listview来显示动态发送者的头像,昵称以及发送时间. 那回复怎么办呢? gridview的布局与回复较像,效果也比较好.那就用gridview来做回复部分好了. 主要思路就是上图,黑色的由listview显示,红

Asp.net中GridView使用详解(引)

GridView无代码分页排序GridView选中,编辑,取消,删除GridView正反双向排序GridView和下拉菜单DropDownList结合GridView和CheckBox结合鼠标移到GridView某一行时改变该行的背景色方法一鼠标移到GridView某一行时改变该行的背景色方法二GridView实现删除时弹出确认对话框GridView实现自动编号GridView实现自定义时间货币等字符串格式GridView实现用“...”代替超长字符串GridView一般换行与强制换行GridV