ps:承蒙各位厚愛,在博客園中安家的兩個月中我學到了不少東西,認識了許多朋友,且得到了好多機會。目前我有幸翻譯一本atlas的書:foundations of atlas: rapid ajax development with asp.net 2.0,估計三個月后即可于人民郵電出版社并面世。所以這段時間比較忙,blog也不能有前一段時間那么頻繁的更新了,特此表示歉意。當然,歡迎朋友們繼續來討論atlas的相關問題,我會盡力回答。
未來的兩個月內,對于foundations of atlas的翻譯,我希望能夠精益求精,所以一定會有不少問題需要與各位朋友討論,例如術語,翻譯風格等等。在這里我預先感謝了!
在上一篇(請參考:開發asp.net atlas服務器端extender控件——編寫客戶端behavior)中我們已經寫好了客戶端的behavior。在本篇文章中,讓我們將它包裝起來作為服務器端控件運行。
首先來到validateusernameproperties.cs文件,該類繼承于targetcontrolpropertiesbase<control>基類,其中定義的是客戶端屬性值與服務器端屬性值之間的映射關系。同時,targetcontrolpropertiesbase<control>基類以及atlas control extender已經為您做好了產生客戶端xml script的工作,您只需要定義您的behavior需要的屬性即可。
應該加入checkresultlabelid,servicename,methodname,validmessage以及invalidmessage五個屬性。為了簡單,我只舉一個屬性的例子
[defaultvalue("")]
[idreferenceproperty(typeof(webcontrol))]
[requiredproperty()]
public string checkresultlabelid
{
get
{
return getpropertystringvalue("checkresultlabelid");
}
set
{
setpropertystringvalue("checkresultlabelid", value);
}
}
其中checkresultlabelid的定義前面加上了三個屬性:
defaultvalue:設定這個屬性的默認值。
idreferenceproperty:指定這個屬性中只能存放某一特定類型的控件的id。
requiredproperty:指定這個屬性是必須的。
其他的幾個屬性您可以參考隨后提供的源文件。
然后看一下validateusernameextender.cs文件,主要部分如下:
[designer(typeof(validateusernamedesigner))]
[clientscriptresource("dflying", "validateusernamebehavior", "dflying.atlas.controltookit.validateusername.validateusernamebehavior.js")]
[requiredscript(typeof(validateusernameextender))]
public class validateusernameextender : extendercontrolbase<validateusernameproperties, control>
{
}
其中我們的validateusernameextender繼承于extendercontrolbase<validateusernameproperties, control>基類,得到一些共有的操作。并且在類上應用了三個屬性:
designer:指定這個extender的設計器(用于提供設計期支持)的類名。
clientscriptresource:指定生成客戶端atlas xml腳本所需要的信息。這里的dflying和validateusernamebehavior都要和前面的validateusernamebehavior.js中定義的保持一致。
requiredscript:指定客戶端需要的腳本,這樣atlas會以axd文件的形式將validateusernamebehavior.js鏈接到頁面上。
最后是validateusernamedesigner.cs文件,在這里您可以添加設計期的支持程序。讓您的控件在visual studio中隨著設定的屬性值不同,顯示樣式也不同。這里為了簡化,我就不添加設計期支持了。
值此為止,我們的extender就寫好了,來一次release build以后生成的dll就可以直接拿來使用了。在下一篇文章中,我將演示在實際程序中應用這個extender。
新聞熱點
疑難解答
圖片精選