亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

ASP.NET2.0服務器控件之Render方法

2020-01-18 01:54:20
字體:
來源:轉載
供稿:網友
  控件呈現是指向HTTP輸出流中寫入標記文本的過程。服務器通過HTTP輸出流向客戶端發送生成的標記文本,這些文本將會通過客戶端瀏覽器轉換為可視化的元素顯示出來。使用控件呈現,開發人員可以將HTML標記、腳本代碼、CSS樣式表等等輸入到客戶端瀏覽器。實現服務器控件呈現主要有兩種方式:一是Control類的Render方法,二是WebControl的RenderContents方法。本文重點介紹使用Control類的Render方法實現控件呈現的應用。

  使用HtmlTextWriter類

  Control類的Render方法主要用于實現控件呈現,其聲明代碼如下:

protected virtual void Render(HtmlTextWriter output)


  如上代碼所示,Render方法的參數是一個HtmlTextWriter類型。為了更好的應用Render方法,讀者應首先了解HtmlTextWriter類及其相關內容。

  根據MSDN2005的描述,HtmlTextWriter類用于將標記字符和文本寫入到ASP.NET服務器控件輸出流。此類提供了ASP.NET服務器控件在向客戶端呈現標記時所使用的格式設置功能。為了實現類的功能,HtmlTextWriter類定義了多個字段、屬性和方法。由于成員對象眾多,本文只挑選了一些常用成員加以說明,同時,還將介紹一些ASP.NET 2.0的新增成員。

  常用成員對象包括:

  ?AddAttribute方法

  對于HtmlTextWriter對象通過對RenderBeginTag方法的后續調用創建的元素,向其開始標記中添加指定的標記屬性和值。

  ?AddStyleAttribute方法

  對于 HtmlTextWriter 對象通過對 RenderBeginTag 方法的后續調用創建的元素,向其開始標記中添加標記樣式屬性。

  ?Write方法

  將指定數據類型連同任何掛起的制表符間距一起寫入到輸出流。

  ?WriteAttribute方法

  將標記屬性及其值寫入到輸出流。

  ?WriteBeginTag方法

  任何制表符間距和指定標記元素的開始標記寫入到輸出流。

  ?WriteEndTag方法

  寫入指定的標記元素的任何制表符間距和結束標記。

  ?Encoding屬性

  獲取 HtmlTextWriter 對象用于將內容寫入頁的編碼。

  ?Indent屬性

  獲取或設置用以縮進每一行標記的開始位置的制表符位置數。

  ?NewLine屬性

  獲取或設置由 HtmlTextWriter 對象使用的行結束符字符串。

  對于初學者而言,建議重點掌握以上成員對象的應用。另外,ASP.NET 2.0還為HtmlTextWriter類新增了一些成員,這些成員包括:

  ?BeginRender方法

  通知 HtmlTextWriter 對象或派生類的對象,某個控件將會呈現。

  ?EndRender方法

  通知 HtmlTextWriter 對象或某個派生類的對象,某控件已完成呈現。

  ?IsValidFormAttribute方法

  檢查一個屬性以確保它可以在 <form> 標記元素的開始標記中呈現。

  ?WriteEncodedUrl方法

  對指定的 URL 進行編碼,然后將它寫入到輸出流。URL 可以包括參數。

  ?WriteEncodedText方法

  對請求的設備的指定文本進行編碼,然后將其寫入到輸出流。

  ?WriteBreak方法

  將 <br /> 標記元素寫入到輸出流。

  使用Render方法實現控件呈現

  1、基礎知識

  本文所講解的Render方法隸屬于System.Web.UI.Controls.Control類。該類是創建服務器控件的基類,很多控件類均繼承自該類。在Control類中包括三個用于實現控件呈現的方法:Render、RenderChildren和RenderControl。它們都使用HtmlTextWriter的實例作為參數,它們允許為一個HtmlTextWriter對象提供服務器控件的內容,并將其內容封裝至HTTP輸出流中輸出到客戶端顯示。下面簡單對這三個方法進行簡單介紹。

  (1) protected virtual void Render(HtmlTextWriter writer);

  該方法用于將服務器控件內容發送到提供的HtmlTextWriter對象,此對象編寫將在客戶端呈現的內容。在開發服務器控件時,可以重寫此方法以呈現服務器控件。

  (2) protected virtual void RenderChildren(HtmlTextWriter writer);

  該方法用于將服務器控件子級的內容輸出到提供的HtmlTextWriter對象,此對象編寫將在客戶端呈現的內容。該方法通知ASP.NET呈現頁中的所有Active Server Pages代碼。如果頁上沒有任何ASP代碼,此方法將呈現服務器控件的所有子控件。

  (3) protected virtual void RenderControl(HtmlTextWriter writer);和protected void RenderControl (HtmlTextWriter writer,ControlAdapter adapter)

  RenderControl有兩個重載方法,它們都用于將服務器控件的內容輸出到所提供的HtmlTextWriter對象中。如果已啟用跟蹤功能,則存儲有關控件的跟蹤信息。如果服務器控件的Visible屬性設置為true,該方法將確定是否啟用頁的跟蹤功能。如果啟用,它將存儲與控件有關的跟蹤信息,同時向頁呈現服務器控件的內容。另外,前一個重載方式是ASP.NET 2.0從ASP.NET 1.0中繼承而言,后一個重載方式是ASP.NET 2.0新增的。后者具體使用提供的ControlAdapter對象將服務器控件內容輸出到提供的HtmlTextWriter對象。其中參數adapter是ControlAdapter類型,它用于定義呈現的ControlAdapter。當實現在各種設備和瀏覽器中運行的服務器控件時,該方法比較常用。

  以上3個方法看起來好像是獨立的3個方法,然而,實際上它們之間存在密切的聯系。讀者可通過閱讀以下示意性代碼,從而理解它們之間的關系。

//RenderCotrol方法基本實現
public void RenderControl(HtmlTextWriter output)
{
 if(Visible)
 {
  Render(output);
 }
}
//Render方法基本實現
protected virtual void Render(HtmlTextWriter output)
{
 RenderChildren(output);
}
//RenderChildren方法基本實現
protected virtual void RenderChildren(HtmlTextWriter output)
{
 foreach(Control c in Controls)
 {
  c.RenderControl(output);
 }
}

  如上代碼所示,其中列舉了RenderControl、Render、RenderChildren方法的實現思路。顯而易見的是,在控件呈現過程中,這三個方法都在起著作用,而且使用了一個簡單的遞歸調用過程。大體而言,可以理解為:

 ?。?)頁面框架建立一個HtmlTextWriter類的實例;

  (2)頁面框架將這個實例對象傳遞給RenderControl方法;

 ?。?)RenderControl方法檢查控件的可視屬性Visible是否為true。如果為true,RenderControl方法將調用Render方法;如果為false,則不呈現該控件和其子控件;

  (4)Render方法執行默認實現,調用RenderChildren方法;

 ?。?)RenderChildren方法按照默認實現中的設定調用每個子控件的RenderControl方法;

  實際上,如果讀者短時間內不能理解以上過程也沒有很大的關系。對于初學者而言,關鍵是要記住最重要、最常用的是Render方法。控件開發者可以通過重寫Render方法完成呈現控件的任務。

  2、示例應用

  上文介紹了使用Control類的Render方法實現控件呈現的基礎知識。下面將通過一個典型示例,幫助讀者初步理解Render的使用方法。示例效果如圖1所示。

按此在新窗口瀏覽圖片
圖1效果圖

  如圖1所示,該服務器控件呈現了一個超鏈接,并且設置了文本為紅色。當用戶單擊紅色文字時,頁面將轉向微軟站點。當然,用戶可以通過屬性LinkUrl來設置超鏈接地址。

  下面列舉了示例實現源代碼。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace UsingRenderControl
{
 [DefaultProperty("LinkUrl")]
 [ToolboxData("<{0}:RenderControl runat=server></{0}:RenderControl>")]
 public class RenderControl : Control
 {
  // 實現LinkUrl
  [Bindable(true)]
  [Category("Appearance")]
  [DefaultValue("http://localhost/")]
  [Localizable(true)]
  public string LinkUrl
  {
   get { String s = (String)ViewState["LinkUrl"];
    return ((s == null) ? String.Empty : s);}
   set { ViewState["LinkUrl"] = value; }
  }
  // 重寫Render方法
  protected override void Render(HtmlTextWriter writer)
  {
   writer.AddAttribute(HtmlTextWriterAttribute.Href, LinkUrl);
   writer.AddStyleAttribute(HtmlTextWriterStyle.Color, "red");
   writer.RenderBeginTag(HtmlTextWriterTag.A);
   writer.Write("瀏覽網站");
   writer.RenderEndTag();
  }
 }
}

  如上代碼實現了自定義服務器控件類RenderControl。該類從Control基類繼承,具體實現了表示超鏈接地址的LinkUrl(默認值為http://localhost/),并重寫了Render方法。在重寫Render的過程中,調用了一些HtmlTextWriter類成員,例如,Writer、AddAttribute、AddStyleAttribute、RenderBeginTag和RenderEndTag方法等。另外,可能開發人員在使用Writer方法過程中,需要呈現一個比較長的字符串。建議此時多多使用Writer方法,而不要使用字符串級聯或者StringBuilder類的相關方法進行實現。因為,那樣將會消耗大量的系統時間和內存,效率較低。

  可能有一些讀者會問,如果將服務器控件呈現的多行代碼的順序變化一下,是否會有什么不同呢?例如,假設首先依次應用RenderBeginTag、Write、RenderEndTag方法,然后再調用AddAttribute和AddStyleAttribute方法,那么會顯示相同的效果嗎?答案是否定的。這里需要強調的是:在呈現控件的過程中,首先要定義服務器控件的屬性和CSS樣式等內容,然后再定義服務器控件的主體內容,這種順序不能改變的。

  另外,如果讀者感興趣可以在代碼中實現一個Text屬性,用于獲取或者設置控件所顯示的文本。這樣,在Render方法中,使用Write方法輸出的"瀏覽網站"文字內容則可由Text屬性代替。

  下面列舉了為使用以上的自定義服務器控件,而創建的Default.aspx文件源代碼。

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<%@ Register TagPrefix="Sample" Assembly="UsingRenderControl" Namespace="UsingRenderControl" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>使用Render方法實現控件呈現</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<Sample:RenderControl runat="server" ID="CustomerControl" LinkUrl="http://www.microsoft.com/">
</Sample:RenderControl>
</div>
</form>
</body>
</html>
  以上代碼比較簡單,其中主要聲明了自定義服務器控件RenderControl,并設置其LinkUrl屬性值為http://www.microsoft.com,即微軟站點地址。

  當用戶在瀏覽器中運行以上頁面,并查看相關的Html源文件時,可得到如下的代碼:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title> 使用Render方法實現控件呈現</title>
</head>
<body>
<form name="form1" method="post" action="Default.aspx" id="form1">
<div>
<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value="/wEPDwUJNzMyMTY5NTU2ZGQQYrLd/G+vm1h41r2CEkxID63o5g==" />
</div>
<div>
<a style="color:red;">瀏覽網站</a>
</div>
</form>
</body>
</html>

  通過觀察以上代碼可知,自定義服務器控件RenderControl實際呈現的結果是粗體所示部分的代碼,其最終呈現為一個表示超鏈接的<a>標記。

  小結

  本文首先介紹了HtmlTextWriter類的基本知識,然后講解了使用Render方法實現控件呈現的應用。在隨后的一篇文章中,筆者將說明另外一種實現控件呈現的方法。從服務器控件開發技術總體而言,控件呈現技術是開發過程中最為常用,也是最為簡單的內容。建議讀者能夠熟練掌握其中的內容。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人a在线视频| 日本久久久久久| 亚洲国内高清视频| 奇门遁甲1982国语版免费观看高清| 日韩精品免费电影| 久久天天躁狠狠躁夜夜爽蜜月| 久久国产精品久久久久久| 国内精品久久久久影院优| 日韩精品久久久久久久玫瑰园| 1769国内精品视频在线播放| 久久久国产精品x99av| 日韩美女在线看| 欧美视频在线免费看| 久久国产加勒比精品无码| 亚洲视频综合网| 久久久久久国产精品三级玉女聊斋| 最近2019中文字幕mv免费看| 国产精品网红福利| 中文字幕日韩欧美在线| 国产精品久久久久久久久免费| 97久久精品视频| 国产精品视频大全| 国产精品一区二区三| 操日韩av在线电影| 国产精品成人一区二区三区吃奶| 中文字幕精品视频| 亚洲第一中文字幕在线观看| 亚洲成色www8888| 大荫蒂欧美视频另类xxxx| 亚洲国产精品字幕| 欧美性高跟鞋xxxxhd| 日韩第一页在线| 精品国产一区二区在线| 欧美在线视频网| 国产精品欧美一区二区三区奶水| 亚洲91av视频| 国产精品成久久久久三级| 亚洲精品久久久久久久久久久久久| 欧美肥老妇视频| 亚洲最大av网| 久久91亚洲精品中文字幕| 亚洲男人天堂久| 日韩有码视频在线| 国产亚洲精品久久久久久牛牛| 欧美性感美女h网站在线观看免费| 91大神在线播放精品| 青青a在线精品免费观看| 国产+人+亚洲| 午夜精品久久久久久久男人的天堂| 久久精品成人欧美大片古装| 久热精品视频在线| 国产精品扒开腿做爽爽爽的视频| 国产日韩欧美视频| 欧美日韩国产页| 亚洲精品日韩欧美| 久久综合色88| 亚洲日本成人网| 亚洲a∨日韩av高清在线观看| 欧美乱大交做爰xxxⅹ性3| www.欧美三级电影.com| 色多多国产成人永久免费网站| 91网站在线免费观看| 成人亚洲综合色就1024| 国产一区二区三区毛片| 91精品国产91久久久久久久久| 岛国精品视频在线播放| 精品久久中文字幕久久av| 欧美性猛交丰臀xxxxx网站| 日韩精品免费在线视频观看| 成人免费高清完整版在线观看| www.久久草.com| 国产精品永久在线| 欧美极品少妇xxxxⅹ喷水| 日韩人体视频一二区| 国产精品欧美激情在线播放| 法国裸体一区二区| 亚洲欧洲一区二区三区在线观看| 国产99久久精品一区二区 夜夜躁日日躁| 亚洲精品国产精品自产a区红杏吧| 欧美日韩精品在线视频| 中文字幕自拍vr一区二区三区| 日韩经典第一页| 日韩欧美在线第一页| 国产成人a亚洲精品| 性欧美xxxx视频在线观看| 在线观看日韩www视频免费| 国产ts一区二区| 日韩中文字幕国产| 97国产在线观看| 成人网在线视频| 亚洲色图国产精品| 韩国三级日本三级少妇99| 久久精品视频中文字幕| 91精品视频免费观看| 欧美亚洲视频在线看网址| 91天堂在线观看| 55夜色66夜色国产精品视频| 精品亚洲一区二区| 国产精品美乳在线观看| 欧美亚洲激情在线| 欧美福利在线观看| 91丝袜美腿美女视频网站| 欧美贵妇videos办公室| 亚洲桃花岛网站| 久久精品视频在线观看| 欧美日韩免费网站| 欧美激情videoshd| 欧美精品免费看| 国产精品视频中文字幕91| 国产91在线播放精品91| 少妇激情综合网| 亚洲视频自拍偷拍| 国产女精品视频网站免费| 中文字幕自拍vr一区二区三区| 最近中文字幕mv在线一区二区三区四区| 尤物yw午夜国产精品视频明星| 18一19gay欧美视频网站| 91久久精品美女| 精品久久久久久| 日本三级久久久| 亚洲另类激情图| 日韩av影视综合网| 97视频国产在线| 日韩av中文字幕在线播放| 久久久91精品国产一区不卡| 欧美日韩电影在线观看| 欧美精品手机在线| 欧美激情图片区| 亚洲人精品午夜在线观看| 欧美成人精品xxx| 成人黄色影片在线| 欧美超级免费视 在线| 91美女片黄在线观看游戏| 国产欧美精品在线| 国产精品678| 清纯唯美亚洲激情| 亚洲色图在线观看| 国产精品尤物福利片在线观看| 91视频国产一区| 国产精品美女久久久久av超清| 日韩在线观看高清| 正在播放亚洲1区| 亚洲成人网在线观看| 日韩精品在线免费观看视频| 日韩欧美中文第一页| 国产69精品久久久久久| 欧美黑人狂野猛交老妇| 美女久久久久久久| 国语自产精品视频在线看| 久久精品视频va| 欧美贵妇videos办公室| 久久久精品久久久久| 亚洲精品一区二区久| 欧美激情按摩在线| 日韩av成人在线观看| 日韩有码在线视频| 欧美一级在线播放| 久久精品人人做人人爽| 久久久国产精品一区| 久久久精品视频在线观看| 亚洲va欧美va国产综合剧情| 欧美日韩国产精品一区二区三区四区| 亚洲大尺度美女在线| 成人激情视频网|