[ASP.NET AJAX]Function對象及Type類的方法介紹
2024-09-01 08:29:53
供稿:網友
上一回我們從總體上認識了JavaScript Microsoft AJAX Library由于臨時有事,沒有加入事例顯得有點抽象,這一回一定會通過一些事例更加直觀的來會一會Asp.NET Ajax腳本庫中一個很是重要的類Type。這個類提供了一些擴展面向對象編程的一些反射方法,通過這個類我們可以注冊類似.NET中的一些(如:命名空間,類,枚舉等等)基本類型。這個Type類繼承自window是一個Global類型,不屬于任何命名空間。下面我們來看看Type中的一些基本方法以及是怎樣實一些方法的實現方式...
在認識Type類之前,我們首先要來看一看一個很重要的對象,那就是Function對象。Function對象是JavaScript的內部對象,例如:日期對象(Date),數組對象(Array),字符對象(String)以及(Object,RegExp,Math,Error等)都屬于這種,可以通過new來實例化一個對象。除了我們常見的JavaScript申明的函數,我們也可以用以下的方法構建我們的函數對象:var myFunction=new Function(arguments,statement)。由于我對腳本不是很熟悉,對prototype(不過聽說是通過給出一個原型對象來指明所要創建的對象的類型,然后用這個原型對象的方法創建出更多同類型的對象,原始模型模式屬于對象的創建模式)也不是很了解,不過經過我簡單的測試了一下,如果對Function進行prototype擴展可以通過new來申明對象后再引用他,也可以直接調用Function.(方法或函數)。如果直接運用Function.uName來擴展這個uName就只能通過Function.uName調用,這讓我想起了.NET中的靜態方法(C#:static;VB:share),有了這些我們來看看Asp.NET Ajax中對Function擴展的幾個對象:
代碼如下:
Function.__typeName="Function";
Function.createCallback=function(b,a){
return function(){
var e=arguments.length;
if(e>0){
var d=[];
for(var c=0;c<e;c++)
d[c]=arguments[c];
d[e]=a;
return b.apply(this,d)
}
return b.call(this,a)
}
};
Function.createDelegate=function(a,b){
return function(){
return b.apply(a,arguments)
}
};
Function.emptyFunction=Function.emptyMethod=function(){};
從上面我們可以看出Function擴展了一個屬性(__typeName)和幾個方法(我們可以把它看成.NET中的靜態對象來調用,如果用new Function();再來調用就會得到"undefined";可能這是JavaScript最基本的東西,但是我以前沒有用過這種對象來寫過腳本,也沒有系統的學過JavaScript,所以不要笑話我哦:)正在學習中...),在上面我還發現了一個比較少見的call/apply;網上搜了一下發現在<<全面理解javascript的caller,callee,call,apply概念>>有比較詳細的介紹。如果我沒猜錯的話:Function.createCallback("callback method","callback argument")和回調有關;Function.createDelegate("object通常用this","執行的方法"),即通過Function.createDelegate創建的代理方法繼承了b方法,從而來完成整個代理的過程(不知道是否正確!);Function.emptyFunction/Function.emptyMethod應該是為了接口和虛函數而準備的。