日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能

上一篇討論了如何為子控件添加集合樣式,這次我們討論如何為服務(wù)器控件添加客戶端功能 .

紅塔ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能1.減輕服務(wù)器壓力,增加用戶體驗(yàn)

服務(wù)器功能是強(qiáng)大的,客戶端腳本一點(diǎn)也不弱,現(xiàn)在的ajax技術(shù)和Atlas技術(shù)就是***的證明,我們總是期待UI有一個(gè)好的效果,flash動(dòng)畫給我們帶來了很酷的效果,我們至少也可以為我們的服務(wù)器控件添加客戶端腳本,一方面減少了服務(wù)器端的回傳,一方面又能為控件提供非??岬男Ч?我想我們都很喜歡ATLAS里面很多很酷的控件吧,而且無刷新,服務(wù)器控件與客戶端腳本交互使用,那會(huì)服務(wù)器控件變的更加***.

經(jīng)過上面的廢話,下面我們進(jìn)入正題

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能2.簡(jiǎn)單為服務(wù)器控件添加客戶端腳本

我們已經(jīng)了解到服務(wù)器控件呈現(xiàn)后的代碼仍然為HTML,只要你熟悉此服務(wù)器控件呈現(xiàn)后標(biāo)簽和此標(biāo)簽的元素,你就可以直接在服務(wù)器控件中添加

屬性,事件,樣式等等

簡(jiǎn)單的添加方法如下:

(1)直接在控件添加屬性,如為Button控件添加簡(jiǎn)單的客戶端事件

 
 
 
  1. ﹤asp:Button ID="Button2" runat="server" Text="Button" 
  2. onmouseover="this.value='鼠標(biāo)經(jīng)過'" onmouseout="this.value='鼠標(biāo)離開'"  /﹥

(2)使用AttributeCollection在后臺(tái)添加添加簡(jiǎn)單的客戶端事件,很典型的使用如我們?cè)趧h除數(shù)據(jù)的時(shí)候總要彈出一個(gè)窗口提醒用戶是否刪除.

 
 
 
  1. Button2.Attributes.Add("onmouseover", "this.value='鼠標(biāo)經(jīng)過'");
  2. Button2.Attributes.Add("onmouseout", "this.value='鼠標(biāo)離開'");

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能3.復(fù)雜客戶端功能處理

先不論服務(wù)器端的功能,當(dāng)客戶端腳本復(fù)雜以后,我們會(huì)寫在一個(gè)js文件里,可以復(fù)用,簡(jiǎn)單的腳本邏輯可以﹤script﹥標(biāo)簽內(nèi).我們需要封裝.

Page類為我們提供了幾個(gè)方法用于實(shí)現(xiàn)以下內(nèi)容,但需要注意的是,asp.net2.0新加了一個(gè)類ClientScriptManager,專門用于管理客戶端腳本的方法,使用方法為

ClientScriptManager = Page.ClientScript;

(1)注冊(cè)腳本庫(js文件)

RegisterClientScriptInclude 方法

(2)發(fā)出位于頁面頂部和尾部的腳本

RegisterStartupScript方法和RegisterClientScriptBlock方法

(3)確保腳本塊在頁面只出現(xiàn)一次

以Is帶頭Registered結(jié)尾的四個(gè)方法

(4)將控件事件處理程序與客戶端提交事件關(guān)聯(lián)起來

RegisterOnSubmitStatement 方法

(5)注冊(cè)一個(gè)數(shù)組用來存儲(chǔ)控件自身變量

RegisterArrayDeclaration方法

(6)注冊(cè)一個(gè)隱藏域

RegisterHiddenField 方法

對(duì)于以上方法的具體使用MSDN均給出了具體的示例,剛看的時(shí)候感覺方法名比較長(zhǎng),接觸后就會(huì)感覺簡(jiǎn)單了,對(duì)以上方法的使用一定要了解.如果你不想看MSDN的話,那么推薦看下面幾篇文章,相信對(duì)你會(huì)有很大幫助.還有建議大家可以看下呈現(xiàn)后的HTML代碼,這樣會(huì)加深理解.

從 ASP.NET 服務(wù)器控件插入客戶端腳本

使用客戶端腳本

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能4.了解預(yù)呈現(xiàn)PreRender事件

這里還是要講控件的生命周期,在控件呈現(xiàn)Render方法之前,還有一個(gè)預(yù)呈現(xiàn)OnPreRender 方法.其周期是在OnLoad之后的MSDN給出了其解釋

在呈現(xiàn)輸出之前執(zhí)行任何更新??梢员4嬖陬A(yù)呈現(xiàn)階段對(duì)控件狀態(tài)所做的更改,而在呈現(xiàn)階段所對(duì)的更改則會(huì)丟失

總結(jié)的話,總是很簡(jiǎn)單的,要深刻理解的話,還是需要我們?nèi)ピ囼?yàn)一下,再回來體驗(yàn)上面這句話

先看一個(gè)簡(jiǎn)單的例子,在頁面上重寫了Page_PreRender,在其事件中給label1賦值,然后再定義了button事件,你會(huì)發(fā)現(xiàn)button事件觸發(fā)后label的值還是保持不變.

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能示例一

 
 
 
  1. protected void Page_PreRender(object sender, EventArgs e)
  2.     
  3. {
  4.     Label1.Text="PreRender";
  5.     
  6. }
  7. protected void Button1_Click(object sender, EventArgs e)
  8. {
  9.     Label1.Text = "Click";
  10. }

再理解上面這句話,可能我們想為什么不在呈現(xiàn)的時(shí)候Render方法中實(shí)現(xiàn)呢?如果這么做的話,那你就要屬性定死了.

我們還需要說明一點(diǎn),不同事件負(fù)責(zé)不同的事情,Render方法只負(fù)責(zé)呈現(xiàn),不要把別的事情交給他做.

你可以在Render方法為控件添加需要呈現(xiàn)的屬性,但其他事情則需要在呈現(xiàn)之前完成.整個(gè)控件的周期是有階段,不同階段完成不同事情.

我們這次討論的是為服務(wù)器控件添加客戶端腳本,那么我們就要在控件適當(dāng)?shù)臅r(shí)機(jī)調(diào)用ClientScriptManager類的方法.而這個(gè)適當(dāng)?shù)臅r(shí)機(jī)就是OnPreRender 方法了.

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能5.在自定義控件中添加客戶端腳本

(1)簡(jiǎn)單的實(shí)現(xiàn):你可以重些OnPreRender方法,然后用AttributeCollection的Add方法,添加簡(jiǎn)單客戶端腳本

 
 
 
  1. protected override void OnPreRender(EventArgs e)
  2. {
  3.    base.OnPreRender(e);
  4.    Attributes.Add("onclick","alert('" + ClickText + "');");
  5. }

(2)復(fù)雜的實(shí)現(xiàn): 這里我們用的例子還是簡(jiǎn)單點(diǎn)吧,效果還是按鈕確認(rèn)之前有一個(gè)彈出窗口,重要的是大家要了解ClientScriptManager類中幾個(gè)方法的使用,以下的代碼使用的是 asp.net服務(wù)器控件開發(fā)技術(shù)與實(shí)例的實(shí)例2 ,我偷懶,直接就用Page里的幾個(gè)方法的.

以下列出代碼

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能示例二

 
 
 
  1. /**//// ﹤summary﹥
  2.     /// NormalButton 顯示為一個(gè)普通樣式按鈕。
  3.     /// 當(dāng)用戶點(diǎn)擊按鈕之后,跳出一個(gè)確認(rèn)對(duì)話框來確定其動(dòng)作。
  4.     /// 通常多用于確認(rèn)用戶是否確實(shí)要進(jìn)行刪除/修改等類似的操作。
  5.     /// ﹤/summary﹥
  6.     [ToolboxData("﹤{0}:NormalButton runat=server﹥﹤/{0}:NormalButton﹥")]
  7.     public class NormalButton : Button
  8.     {
  9.         private string _scriptPath = "ControlClientScript/";
  10.         //構(gòu)造函數(shù)
  11.         public NormalButton():base()
  12.         {
  13.             Message = "您確實(shí)要這樣做嗎?";
  14.         }
  15.         
  16.         定義屬性#region 定義屬性
  17.         [Bindable(true), 
  18.         Category("Appearance"), 
  19.         DefaultValue("您確實(shí)要這樣做嗎?"),
  20.         Description("自定義提示信息")] 
  21.         public string Message 
  22.         {
  23.             get
  24.             {
  25.                 return (string)ViewState["Message"];
  26.             }
  27.             set
  28.             {
  29.                 ViewState["Message"] = value;
  30.             }
  31.         }
  32.         
  33.         [Category("Other"), 
  34.         DefaultValue("ControlClientScript/"),
  35.         Description("腳本路徑")]
  36.         public String ScriptPath 
  37.         {
  38.             get 
  39.             {
  40.                 return _scriptPath;
  41.             }
  42.             set
  43.             {
  44.                 _scriptPath = value;
  45.             }
  46.         }
  47.         #endregion
  48.         //重寫AddAttributesToRender方法
  49.         protected override void AddAttributesToRender(HtmlTextWriter output)
  50.         {
  51.             Attributes.Add("confirmationmessage",Message);
  52.             base.AddAttributesToRender(output);
  53.         }
  54.         //重寫OnPreRender方法
  55.         protected override void OnPreRender( EventArgs e ) 
  56.         {
  57.             Page.RegisterClientScriptBlock( "WebUIConfirmation",
  58. "﹤script language='javascript' src='" + ScriptPath +
  59. "WebUIConfirmation.js" + "'﹥﹤/script﹥" );
  60.             Page.RegisterArrayDeclaration("Page_Confirmations",
  61.  "'" + ClientID + "'" );
  62.             Page.RegisterStartupScript( "WebUIConfirmation Startup",
  63.  "﹤script language='javascript' src='" + ScriptPath +
  64. "WebUIConfirmationStartup.js" + "'﹥﹤/script﹥" );
  65.             base.OnPreRender(e);
  66.         }
  67.     }

主要看OnPreRender方法,只要你對(duì)其幾個(gè)方法熟悉后,那剩下就是你對(duì)javaScript的掌握程度了.掌握上面幾個(gè)方法可以說很容易,對(duì)javaScript的掌握那需要平時(shí)的積累了,所以要開發(fā)一個(gè)好的控件,并不容易呀.

下面再列出js文件,我對(duì)其梢有改動(dòng)

 
 
 
  1. WebUIConfirmationStartup.js
  2. ConfirmationOnLoad();
  3. WebUIConfirmation.js
  4. //String去空格
  5. String.prototype.Trim = function()
  6. return this.replace(/(^\s*)|(\s*$)/g, "");
  7. }
  8. //初始化獲取控件ID
  9. function ConfirmationOnLoad() {    
  10.     if (typeof(Page_Confirmations) == "undefined") return;
  11.     var i, confirmButton;
  12.     for (i = 0; i ﹤ Page_Confirmations.length; i++) {
  13.         confirmButton = Page_Confirmations[i];
  14.         if (typeof(confirmButton) == "string") {
  15.             confirmButton = document.getElementById( confirmButton );
  16.         }        
  17.         if (typeof(confirmButton.confirmationmessage ) != "undefined" ) {
  18.             if ( confirmButton.attributes["confirmationmessage"].value.Trim() != "" ) {
  19.                 confirmButton.confirmationmessage = confirmButton.attributes["confirmationmessage"].value;
  20.             } else {
  21.                 confirmButton.confirmationmessage = "您確實(shí)要這樣做嗎?";
  22.             }
  23.         }
  24.         ConfirmationHookupControl(confirmButton);
  25.         
  26.     }
  27. }
  28. //添加onclick事件
  29. function ConfirmationHookupControl( confirmButton ) {
  30.     var ev = confirmButton.onclick;
  31.     if (typeof(ev) == "function" ) {            
  32.         ev = ev.toString();
  33.         ev = ev.substring(ev.indexOf("{") + 1, ev.lastIndexOf("}"));
  34.     }
  35.     else {
  36.         ev = "";
  37.     }
  38.     var func = new Function("if ( !ConfirmationOnClick( this ) ){return false;} " + ev);
  39.     confirmButton.onclick = func;
  40. }
  41. //彈出確認(rèn)窗口
  42. function ConfirmationOnClick( confirmButton ) {
  43.     return window.confirm( confirmButton.confirmationmessage );
  44. }

OK,上面的服務(wù)器控件代碼還是挺簡(jiǎn)單的,你看的懂JS的話,那這個(gè)效果就沒問題了.其實(shí)說真的,難點(diǎn)在于JavaScript腳本,呵呵.

下面再說一個(gè)例子吧,也是asp.net服務(wù)器控件開發(fā)技術(shù)與實(shí)例的例子,是一個(gè)可伸縮面板控件,其是一個(gè)集合屬性和客戶端腳本一起實(shí)現(xiàn)的效果

但此控件卻并在呈現(xiàn)頁面上用到j(luò)s腳本,也沒重寫OnPreRender方法,而是定義了一個(gè)HTC,其關(guān)鍵實(shí)現(xiàn)是服務(wù)器控件的集合屬性的實(shí)現(xiàn),還有就是客戶端腳本的實(shí)現(xiàn),具體代碼可以在后面下載.

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能其他需要注意的問題:

1.客戶端腳本在服務(wù)器控件中的最頻繁的使用則是驗(yàn)證控件的使用了,你也可以自定義驗(yàn)證控件,但我感覺用處不是很大,如果需要你可以了解下System.Web.UI.IValidator 接口和System.Web.UI.WebControls.BaseValidator類

2.另外還有客戶端回調(diào),你可以了解下ICallbackEventHandler接口,具體還是看相關(guān)文章或者M(jìn)SDN吧.

好了又寫完一篇了,如果你剛接觸這些東西的話,對(duì)你還是有幫助的,如果你已經(jīng)了解了,我上面講的對(duì)你來說就很簡(jiǎn)單了.還是想那樣說,關(guān)鍵在于你對(duì)JavaScript的熟練程度.一些東西還需要你自己去挖掘.

ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能的相關(guān)內(nèi)容就向你介紹到這里,希望對(duì)你了解ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能有所幫助。


文章題目:ASP.NET控件開發(fā)基礎(chǔ)之服務(wù)器控件客戶端功能
文章路徑:http://m.5511xx.com/article/coiphdo.html