[ASP.NET AJAX]Function對(duì)象及Type類的方法介紹
更新時(shí)間:2007年01月07日 00:00:00 作者:
上一回我們從總體上認(rèn)識(shí)了JavaScript Microsoft AJAX Library由于臨時(shí)有事,沒有加入事例顯得有點(diǎn)抽象,這一回一定會(huì)通過(guò)一些事例更加直觀的來(lái)會(huì)一會(huì)Asp.NET Ajax腳本庫(kù)中一個(gè)很是重要的類Type。這個(gè)類提供了一些擴(kuò)展面向?qū)ο缶幊痰囊恍┓瓷浞椒?,通過(guò)這個(gè)類我們可以注冊(cè)類似.NET中的一些(如:命名空間,類,枚舉等等)基本類型。這個(gè)Type類繼承自window是一個(gè)Global類型,不屬于任何命名空間。下面我們來(lái)看看Type中的一些基本方法以及是怎樣實(shí)一些方法的實(shí)現(xiàn)方式...
在認(rèn)識(shí)Type類之前,我們首先要來(lái)看一看一個(gè)很重要的對(duì)象,那就是Function對(duì)象。Function對(duì)象是JavaScript的內(nèi)部對(duì)象,例如:日期對(duì)象(Date),數(shù)組對(duì)象(Array),字符對(duì)象(String)以及(Object,RegExp,Math,Error等)都屬于這種,可以通過(guò)new來(lái)實(shí)例化一個(gè)對(duì)象。除了我們常見的JavaScript申明的函數(shù),我們也可以用以下的方法構(gòu)建我們的函數(shù)對(duì)象:var myFunction=new Function(arguments,statement)。由于我對(duì)腳本不是很熟悉,對(duì)prototype(不過(guò)聽說(shuō)是通過(guò)給出一個(gè)原型對(duì)象來(lái)指明所要?jiǎng)?chuàng)建的對(duì)象的類型,然后用這個(gè)原型對(duì)象的方法創(chuàng)建出更多同類型的對(duì)象,原始模型模式屬于對(duì)象的創(chuàng)建模式)也不是很了解,不過(guò)經(jīng)過(guò)我簡(jiǎn)單的測(cè)試了一下,如果對(duì)Function進(jìn)行prototype擴(kuò)展可以通過(guò)new來(lái)申明對(duì)象后再引用他,也可以直接調(diào)用Function.(方法或函數(shù))。如果直接運(yùn)用Function.uName來(lái)擴(kuò)展這個(gè)uName就只能通過(guò)Function.uName調(diào)用,這讓我想起了.NET中的靜態(tài)方法(C#:static;VB:share),有了這些我們來(lái)看看Asp.NET Ajax中對(duì)Function擴(kuò)展的幾個(gè)對(duì)象:
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擴(kuò)展了一個(gè)屬性(__typeName)和幾個(gè)方法(我們可以把它看成.NET中的靜態(tài)對(duì)象來(lái)調(diào)用,如果用new Function();再來(lái)調(diào)用就會(huì)得到"undefined";可能這是JavaScript最基本的東西,但是我以前沒有用過(guò)這種對(duì)象來(lái)寫過(guò)腳本,也沒有系統(tǒng)的學(xué)過(guò)JavaScript,所以不要笑話我哦:)正在學(xué)習(xí)中...),在上面我還發(fā)現(xiàn)了一個(gè)比較少見的call/apply;網(wǎng)上搜了一下發(fā)現(xiàn)在<<全面理解javascript的caller,callee,call,apply概念>>有比較詳細(xì)的介紹。如果我沒猜錯(cuò)的話:Function.createCallback("callback method","callback argument")和回調(diào)有關(guān);Function.createDelegate("object通常用this","執(zhí)行的方法"),即通過(guò)Function.createDelegate創(chuàng)建的代理方法繼承了b方法,從而來(lái)完成整個(gè)代理的過(guò)程(不知道是否正確!);Function.emptyFunction/Function.emptyMethod應(yīng)該是為了接口和虛函數(shù)而準(zhǔn)備的。
Type對(duì)象繼承了Function對(duì)象,由Function對(duì)象進(jìn)一步延伸,在這里我們就不討論Type地實(shí)現(xiàn)過(guò)程,我們今天主要來(lái)看看Type中的一些重要的方法。Type中總共有22個(gè)方法,下面我們將逐個(gè)進(jìn)行介紹:
.[prototype]Type.callBaseMethod(instance,name,baseArguments)
說(shuō)明:
這個(gè)函數(shù)主要調(diào)用基函數(shù)中的方法,相當(dāng)于C#中的base;這個(gè)函數(shù)只有在繼承函數(shù)時(shí)才會(huì)用到。
參數(shù):
instance:將要被調(diào)用的基函數(shù)的當(dāng)前實(shí)例,通常用this;
name:將要被調(diào)用的基函數(shù)的名稱,用字符串表示;
baseArguments:將要被調(diào)用的基函數(shù)的參數(shù)。
.[prototype]Type.getBaseMethod(instance,name)
說(shuō)明:
引用基函數(shù)的方法實(shí)例,如果你要通過(guò)Function.call函數(shù)來(lái)調(diào)用一個(gè)方法,這將是你的選擇;不過(guò)我覺得和上一個(gè)函數(shù)的差別不是特別大,糊涂了。
參數(shù):
instance:在這個(gè)函數(shù)中好像沒有被調(diào)用,上一個(gè)函數(shù)的實(shí)現(xiàn)是通過(guò)這個(gè)函數(shù)來(lái)獲取函數(shù)的,可能這個(gè)參數(shù)是為1中的instance參數(shù)預(yù)留的,我也搞不懂他們?yōu)槭裁催@樣干,高手自由高手的道理吧!
name:當(dāng)然是所要引用的方法的名稱。
.[prototype]Type.getBaseType()
說(shuō)明:
其實(shí)就是返回"typeof this.__baseType"的值,如果是"undefined"則返回null。
.[prototype]Type.getInterfaces()
說(shuō)明:
通過(guò)這個(gè)可以獲取當(dāng)前實(shí)例所實(shí)現(xiàn)的接口對(duì)象數(shù)組,為一個(gè)Array對(duì)象。
.[prototype]Type.getName()
說(shuō)明:
返回當(dāng)前對(duì)象的名稱,包括命名空間和類名稱,如果為"undefined"返回""。
.[prototype]Type.implementsInterface(interfaceType)
說(shuō)明:
如果當(dāng)前類已經(jīng)實(shí)現(xiàn)了interfaceType接口中的所有定義,則返回true,否則返回false。這也就可以實(shí)現(xiàn)在.NET中繼承借口必須實(shí)現(xiàn)所有方法或?qū)傩缘闹Z言:)
.[prototype]Type.inheritsFrom(parentType)
說(shuō)明:
調(diào)用此方法可以判斷當(dāng)前實(shí)例是否繼承自parentType類,如:var isInherited=ClassA.inheritsFrom(ClassB);如果當(dāng)前實(shí)例繼承自parentType則返回true,否則返回false。
.[prototype]Type.initializeBase(instance, baseArguments)
說(shuō)明:
這是一個(gè)相當(dāng)重要的函數(shù),通過(guò)這個(gè)函數(shù)來(lái)初始化基函數(shù)的構(gòu)造函數(shù),也可以將自己注冊(cè)為一個(gè)基函數(shù)。其中instance是初始化基類的對(duì)象,通常用this;baseArguments為基函數(shù)構(gòu)造函數(shù)的參數(shù),可以為空。
.[prototype]Type.isImplementedBy(typeInstance)
說(shuō)明:
這個(gè)和6中正好相反,用來(lái)判斷typeInstance是否實(shí)現(xiàn)了接口中的所有定義,如果是實(shí)現(xiàn)返回true,否則返回false。
.[prototype]Type.isInstanceOfType(instance)
說(shuō)明:
判斷類是否為instance的當(dāng)前實(shí)例,主要用于要判斷類是否為繼承自他的類(子類)的實(shí)例。返回true/false。
.[prototype]Type.registerClass(typeName, baseType, interfaceTypes)
說(shuō)明:
這個(gè)一看就知道是注冊(cè)一個(gè)類的,baseType和interfaceTypes都是可選的,同時(shí)和.NET的一樣,baseType最多一個(gè),而接口就無(wú)所謂了。這個(gè)方法用在定一個(gè)類以后初始化之前,如果有baseType須在第一行通過(guò)Type.initializeBase來(lái)實(shí)例化基函數(shù)的構(gòu)造函數(shù)。
.[prototype]Type.registerInterface(typeName)
說(shuō)明:
將一個(gè)類注冊(cè)為接口,接口中部包含任何的處理函數(shù)。
.[prototype]Type.resolveInheritance()
說(shuō)明:
這個(gè)方法很好玩,拷貝基類的屬性,來(lái)對(duì)當(dāng)前類進(jìn)行prototype擴(kuò)展,可也就是擴(kuò)展面向?qū)ο缶幊讨械姆瓷洹?
.Type.getRootNamespaces()
說(shuō)明:
靜態(tài)函數(shù)(我不知道別人怎么叫,我就叫他靜態(tài)函數(shù)就好了:),通過(guò)這個(gè)方法可以獲取所有命名空間的Array數(shù)組(即返回一個(gè)數(shù)組,包含所有命名空間)。
.Type.isClass(type)
.Type.isInterface(type)
.Type.isNamespace(type)
.Type.parse(typeName,ns)
說(shuō)明:
厲害了,通過(guò)這個(gè)可以創(chuàng)建一個(gè)對(duì)象,即.NET中的利用Type.GetType("type,ns");和Invoke();來(lái)反射實(shí)例化一個(gè)類。ns命名空間可選項(xiàng)。如果類沒有位于一個(gè)命名空間中(如:Type類),typeName可以為null。
.Type.registerNamespace(namespacePath)
說(shuō)明:
注冊(cè)一個(gè)命名空間。
.[prototype]Type.registerEnum(name,flag)
說(shuō)明:
注冊(cè)為枚舉類型,flag判斷是否為bit類型,可選。
.Type.isEnum(type)
.Type.isFlags(type)
寫著寫著胡了,例子還是沒有加上,而且原來(lái)的理解好像很模糊,為了讓人能更直觀的理解,我把有些例子放在這里(html文件):
如果要測(cè)試Enum要用<ScriptManager/>空間引用腳本,提供例子里的腳本沒有Number類的擴(kuò)展,所以不能測(cè)試Enum,哎,幾個(gè)小時(shí)就這樣過(guò)去了,不過(guò)也掌握了不少,在我寫這篇文章是越來(lái)越覺得很模糊,如果有什么錯(cuò)誤的地方請(qǐng)大家指出,允許Bill Gate先富起來(lái),然后帶動(dòng)我們富裕,最后實(shí)現(xiàn)大家共同富裕嗎:)
在認(rèn)識(shí)Type類之前,我們首先要來(lái)看一看一個(gè)很重要的對(duì)象,那就是Function對(duì)象。Function對(duì)象是JavaScript的內(nèi)部對(duì)象,例如:日期對(duì)象(Date),數(shù)組對(duì)象(Array),字符對(duì)象(String)以及(Object,RegExp,Math,Error等)都屬于這種,可以通過(guò)new來(lái)實(shí)例化一個(gè)對(duì)象。除了我們常見的JavaScript申明的函數(shù),我們也可以用以下的方法構(gòu)建我們的函數(shù)對(duì)象:var myFunction=new Function(arguments,statement)。由于我對(duì)腳本不是很熟悉,對(duì)prototype(不過(guò)聽說(shuō)是通過(guò)給出一個(gè)原型對(duì)象來(lái)指明所要?jiǎng)?chuàng)建的對(duì)象的類型,然后用這個(gè)原型對(duì)象的方法創(chuàng)建出更多同類型的對(duì)象,原始模型模式屬于對(duì)象的創(chuàng)建模式)也不是很了解,不過(guò)經(jīng)過(guò)我簡(jiǎn)單的測(cè)試了一下,如果對(duì)Function進(jìn)行prototype擴(kuò)展可以通過(guò)new來(lái)申明對(duì)象后再引用他,也可以直接調(diào)用Function.(方法或函數(shù))。如果直接運(yùn)用Function.uName來(lái)擴(kuò)展這個(gè)uName就只能通過(guò)Function.uName調(diào)用,這讓我想起了.NET中的靜態(tài)方法(C#:static;VB:share),有了這些我們來(lái)看看Asp.NET Ajax中對(duì)Function擴(kuò)展的幾個(gè)對(duì)象:
復(fù)制代碼 代碼如下:
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擴(kuò)展了一個(gè)屬性(__typeName)和幾個(gè)方法(我們可以把它看成.NET中的靜態(tài)對(duì)象來(lái)調(diào)用,如果用new Function();再來(lái)調(diào)用就會(huì)得到"undefined";可能這是JavaScript最基本的東西,但是我以前沒有用過(guò)這種對(duì)象來(lái)寫過(guò)腳本,也沒有系統(tǒng)的學(xué)過(guò)JavaScript,所以不要笑話我哦:)正在學(xué)習(xí)中...),在上面我還發(fā)現(xiàn)了一個(gè)比較少見的call/apply;網(wǎng)上搜了一下發(fā)現(xiàn)在<<全面理解javascript的caller,callee,call,apply概念>>有比較詳細(xì)的介紹。如果我沒猜錯(cuò)的話:Function.createCallback("callback method","callback argument")和回調(diào)有關(guān);Function.createDelegate("object通常用this","執(zhí)行的方法"),即通過(guò)Function.createDelegate創(chuàng)建的代理方法繼承了b方法,從而來(lái)完成整個(gè)代理的過(guò)程(不知道是否正確!);Function.emptyFunction/Function.emptyMethod應(yīng)該是為了接口和虛函數(shù)而準(zhǔn)備的。
Type對(duì)象繼承了Function對(duì)象,由Function對(duì)象進(jìn)一步延伸,在這里我們就不討論Type地實(shí)現(xiàn)過(guò)程,我們今天主要來(lái)看看Type中的一些重要的方法。Type中總共有22個(gè)方法,下面我們將逐個(gè)進(jìn)行介紹:
.[prototype]Type.callBaseMethod(instance,name,baseArguments)
說(shuō)明:
這個(gè)函數(shù)主要調(diào)用基函數(shù)中的方法,相當(dāng)于C#中的base;這個(gè)函數(shù)只有在繼承函數(shù)時(shí)才會(huì)用到。
參數(shù):
instance:將要被調(diào)用的基函數(shù)的當(dāng)前實(shí)例,通常用this;
name:將要被調(diào)用的基函數(shù)的名稱,用字符串表示;
baseArguments:將要被調(diào)用的基函數(shù)的參數(shù)。
.[prototype]Type.getBaseMethod(instance,name)
說(shuō)明:
引用基函數(shù)的方法實(shí)例,如果你要通過(guò)Function.call函數(shù)來(lái)調(diào)用一個(gè)方法,這將是你的選擇;不過(guò)我覺得和上一個(gè)函數(shù)的差別不是特別大,糊涂了。
參數(shù):
instance:在這個(gè)函數(shù)中好像沒有被調(diào)用,上一個(gè)函數(shù)的實(shí)現(xiàn)是通過(guò)這個(gè)函數(shù)來(lái)獲取函數(shù)的,可能這個(gè)參數(shù)是為1中的instance參數(shù)預(yù)留的,我也搞不懂他們?yōu)槭裁催@樣干,高手自由高手的道理吧!
name:當(dāng)然是所要引用的方法的名稱。
.[prototype]Type.getBaseType()
說(shuō)明:
其實(shí)就是返回"typeof this.__baseType"的值,如果是"undefined"則返回null。
.[prototype]Type.getInterfaces()
說(shuō)明:
通過(guò)這個(gè)可以獲取當(dāng)前實(shí)例所實(shí)現(xiàn)的接口對(duì)象數(shù)組,為一個(gè)Array對(duì)象。
.[prototype]Type.getName()
說(shuō)明:
返回當(dāng)前對(duì)象的名稱,包括命名空間和類名稱,如果為"undefined"返回""。
.[prototype]Type.implementsInterface(interfaceType)
說(shuō)明:
如果當(dāng)前類已經(jīng)實(shí)現(xiàn)了interfaceType接口中的所有定義,則返回true,否則返回false。這也就可以實(shí)現(xiàn)在.NET中繼承借口必須實(shí)現(xiàn)所有方法或?qū)傩缘闹Z言:)
.[prototype]Type.inheritsFrom(parentType)
說(shuō)明:
調(diào)用此方法可以判斷當(dāng)前實(shí)例是否繼承自parentType類,如:var isInherited=ClassA.inheritsFrom(ClassB);如果當(dāng)前實(shí)例繼承自parentType則返回true,否則返回false。
.[prototype]Type.initializeBase(instance, baseArguments)
說(shuō)明:
這是一個(gè)相當(dāng)重要的函數(shù),通過(guò)這個(gè)函數(shù)來(lái)初始化基函數(shù)的構(gòu)造函數(shù),也可以將自己注冊(cè)為一個(gè)基函數(shù)。其中instance是初始化基類的對(duì)象,通常用this;baseArguments為基函數(shù)構(gòu)造函數(shù)的參數(shù),可以為空。
.[prototype]Type.isImplementedBy(typeInstance)
說(shuō)明:
這個(gè)和6中正好相反,用來(lái)判斷typeInstance是否實(shí)現(xiàn)了接口中的所有定義,如果是實(shí)現(xiàn)返回true,否則返回false。
.[prototype]Type.isInstanceOfType(instance)
說(shuō)明:
判斷類是否為instance的當(dāng)前實(shí)例,主要用于要判斷類是否為繼承自他的類(子類)的實(shí)例。返回true/false。
.[prototype]Type.registerClass(typeName, baseType, interfaceTypes)
說(shuō)明:
這個(gè)一看就知道是注冊(cè)一個(gè)類的,baseType和interfaceTypes都是可選的,同時(shí)和.NET的一樣,baseType最多一個(gè),而接口就無(wú)所謂了。這個(gè)方法用在定一個(gè)類以后初始化之前,如果有baseType須在第一行通過(guò)Type.initializeBase來(lái)實(shí)例化基函數(shù)的構(gòu)造函數(shù)。
.[prototype]Type.registerInterface(typeName)
說(shuō)明:
將一個(gè)類注冊(cè)為接口,接口中部包含任何的處理函數(shù)。
.[prototype]Type.resolveInheritance()
說(shuō)明:
這個(gè)方法很好玩,拷貝基類的屬性,來(lái)對(duì)當(dāng)前類進(jìn)行prototype擴(kuò)展,可也就是擴(kuò)展面向?qū)ο缶幊讨械姆瓷洹?
.Type.getRootNamespaces()
說(shuō)明:
靜態(tài)函數(shù)(我不知道別人怎么叫,我就叫他靜態(tài)函數(shù)就好了:),通過(guò)這個(gè)方法可以獲取所有命名空間的Array數(shù)組(即返回一個(gè)數(shù)組,包含所有命名空間)。
.Type.isClass(type)
.Type.isInterface(type)
.Type.isNamespace(type)
.Type.parse(typeName,ns)
說(shuō)明:
厲害了,通過(guò)這個(gè)可以創(chuàng)建一個(gè)對(duì)象,即.NET中的利用Type.GetType("type,ns");和Invoke();來(lái)反射實(shí)例化一個(gè)類。ns命名空間可選項(xiàng)。如果類沒有位于一個(gè)命名空間中(如:Type類),typeName可以為null。
.Type.registerNamespace(namespacePath)
說(shuō)明:
注冊(cè)一個(gè)命名空間。
.[prototype]Type.registerEnum(name,flag)
說(shuō)明:
注冊(cè)為枚舉類型,flag判斷是否為bit類型,可選。
.Type.isEnum(type)
.Type.isFlags(type)
寫著寫著胡了,例子還是沒有加上,而且原來(lái)的理解好像很模糊,為了讓人能更直觀的理解,我把有些例子放在這里(html文件):
如果要測(cè)試Enum要用<ScriptManager/>空間引用腳本,提供例子里的腳本沒有Number類的擴(kuò)展,所以不能測(cè)試Enum,哎,幾個(gè)小時(shí)就這樣過(guò)去了,不過(guò)也掌握了不少,在我寫這篇文章是越來(lái)越覺得很模糊,如果有什么錯(cuò)誤的地方請(qǐng)大家指出,允許Bill Gate先富起來(lái),然后帶動(dòng)我們富裕,最后實(shí)現(xiàn)大家共同富裕嗎:)
相關(guān)文章
ajax的get請(qǐng)求時(shí)緩存處理解決方法
這篇文章主要介紹了ajax的get請(qǐng)求時(shí)緩存處理解決方法,詳細(xì)分析了常見的四種解決方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-02-02kkpager 實(shí)現(xiàn)ajax分頁(yè)查詢功能
kkpager 實(shí)現(xiàn)ajax分頁(yè)查詢功能,前臺(tái)分頁(yè)數(shù)據(jù),適合數(shù)據(jù)少量的時(shí)候,因?yàn)榉猪?yè)的數(shù)據(jù)是從后臺(tái)獲取的,大數(shù)據(jù)的話不建議使用 ,具體前后臺(tái)代碼大家參考下本文吧2017-08-08利用Ajax實(shí)現(xiàn)在腳本里傳值實(shí)例介紹
Ajax實(shí)現(xiàn)在腳本里傳值可以解決實(shí)際上的一些問(wèn)題,本文實(shí)現(xiàn)了一下,感興趣的朋友可以參考下,希望可以幫助到你2013-04-04Ajax實(shí)現(xiàn)表格中信息不刷新頁(yè)面進(jìn)行更新數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)表格中的信息不刷新頁(yè)面進(jìn)行更新數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10axios和ajax的區(qū)別點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于axios和ajax的區(qū)別點(diǎn)總結(jié)內(nèi)容,對(duì)此有興趣的朋友們可以跟著學(xué)習(xí)下。2021-12-12用AJAX實(shí)現(xiàn)頁(yè)面登陸以及注冊(cè)用戶名驗(yàn)證的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇用AJAX實(shí)現(xiàn)頁(yè)面登陸以及注冊(cè)用戶名驗(yàn)證的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10STRUTS+AJAX+JSP 請(qǐng)求到后臺(tái)亂碼問(wèn)題解決方法
STRUTS+AJAX+JSP 請(qǐng)求到后臺(tái)亂碼問(wèn)題可在AJAX請(qǐng)求URL之前把參數(shù)進(jìn)行encodeURI()轉(zhuǎn)碼來(lái)解決,遇到類似情況的朋友可以參考下2013-12-12