zoukankan      html  css  js  c++  java
  • (转)asp.net中Literal与label的区别

    asp.net中Literal与label的区别

    一.Literal Web 服务器控件概述(摘于MSDN)

    可以使用 Literal Web 服务器控件作为页面上其他内容的容器。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;。当希望浏览器显示而不解释标记时,编码将很有用。编码对于安全也很有用,有助于防止在浏览器中执行恶意标记。显示来自不受信任的源的字符串时推荐使用此设置。


    二.Literal和Label到底有什么区别

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

    例如:<span >Label</span>(label的客户端代码)
    <b>尼古拉斯凯奇</b>(Literal的客户端代码)

    literal不可以运用样式。定位布局比较麻烦。

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

        下面再转一下一位达人的实际引用..

    1<OBJECT height=288 width=384 classid=clsid:cfcdaa03-8be4-11cf-b84b-0020afbbccfa VIEWASTEXT>
    2                   <PARAM VALUE="10160"><PARAM VALUE="7620">
    3                   <PARAM VALUE="-1"><PARAM VALUE="0">
    4                   <PARAM VALUE="0"><PARAM VALUE="0">
    5                   <PARAM VALUE="<asp:Literal runat='server'></asp:Literal>">
    6                   <PARAM VALUE="imagewindow"><PARAM VALUE="clip1">
    7                   <PARAM VALUE="0"><PARAM VALUE="0"><PARAM VALUE="0">
    8                   <PARAM VALUE="0"><PARAM VALUE="#000000">
    9               </OBJECT>
    那么如何让这个播放器能根据我们传的参数不同而播放不同的内容呢?上面一段Html
    代码的第5行就指明了这个播放器播放的内容来源,为了实现能根据参数不同播放不同的内容,我们将其Value值设置为一个Literal控件,然后在后置代码中动态的对Literal的Text属性赋值就OK了。代码如下:
           /**//// <summary>
           ///       Author: SHY520    
           ///            http://pw.cnblogs.com
           /// </summary>
           public class ShowVideoContent : System.Web.UI.UserControl
           {
               protected System.Web.UI.WebControls.Literal lt_reader;
               protected System.Web.UI.WebControls.Literal lt_vdate;
               protected System.Web.UI.WebControls.Literal lb_author;
               protected System.Web.UI.WebControls.Literal lt_resource;
               protected System.Web.UI.WebControls.Label lb_title;

               //注意:写在Object中的Literal需要我们手工定义
               Literal lt_src;

               private void Page_Load(object sender, System.EventArgs e)
               {
                   if(Request.QueryString["id"] != null)
                   {
                       int id"].ToString());


    ;       //得到视频新闻内容
                       VideoContent vc = VideoContent.Find(id);

                       lt_reader.Text = vc.Announcer;
                       lt_vdate.Text = vc.Vdate.ToShortDateString();
                       lb_author.Text = vc.Author;
                       lt_resource.Text = vc.Resource;
                       lb_title.Text = vc.Videotitle;
                    
                       //对播放内容赋值
                       lt_src.Text = vc.Linkurl;
                   }
               }
    }

        个人觉得Literal控件有点像服务器的占位符..是一个功能强大的占位符.他不止可以占位HTML元素还可以占位JavaScript代码块..下面是项目中做过的..

        在HTML页的最底部为JavaScript代码块占一个位(其实可以根据实际需要变一变).

        </form>
        <asp:Literal runat="server"></asp:Literal>
    </body>

        在后台代码中..ltScript.Text = "<script type="text/javascript">Select("nav2");</script>";这里调用了签名为Select的标签选择函数..这样可以在后台根据实际需要动态加载JavaScript代码块..非常实用..

  • 相关阅读:
    【RabbitMQ】10 深入部分P3 死信队列(交换机)
    【RabbitMQ】09 深入部分P2 消费限流 & TTL
    【RabbitMQ】08 深入部分P1 可靠性投递
    【RabbitMQ】06 Spring整合RabbitMQ
    【RabbitMQ】07 SpringBoot整合RabbitMQ
    【RabbitMQ】05 通配符模式
    【RabbitMQ】04 路由模式
    【RabbitMQ】03 订阅模式
    【RabbitMQ】02 工作队列模式
    【RabbitMQ】01 简单模式
  • 原文地址:https://www.cnblogs.com/wanshutao/p/3541279.html
Copyright © 2011-2022 走看看