• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    [ASP.NET AJAX]Function對象及Type類的方法介紹

    來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:52:46
    文檔

    [ASP.NET AJAX]Function對象及Type類的方法介紹

    [ASP.NET AJAX]Function對象及Type類的方法介紹:上一回我們從總體上認識了JavaScript Microsoft AJAX Library由于臨時有事,沒有加入事例顯得有點抽象,這一回一定會通過一些事例更加直觀的來會一會Asp.NET Ajax腳本庫中一個很是重要的類Type。這個類提供了一些擴展面向對象編程的一些反射方法,通過這個類
    推薦度:
    導讀[ASP.NET AJAX]Function對象及Type類的方法介紹:上一回我們從總體上認識了JavaScript Microsoft AJAX Library由于臨時有事,沒有加入事例顯得有點抽象,這一回一定會通過一些事例更加直觀的來會一會Asp.NET Ajax腳本庫中一個很是重要的類Type。這個類提供了一些擴展面向對象編程的一些反射方法,通過這個類

    上一回我們從總體上認識了JavaScript Microsoft AJAX Library由于臨時有事,沒有加入事例顯得有點抽象,這一回一定會通過一些事例更加直觀的來會一會Asp.NET Ajax腳本庫中一個很是重要的類Type。這個類提供了一些擴展面向對象編程的一些反射方法,通過這個類我們可以注冊類似.NET中的一些(如:命名空間,類,枚舉等等)基本類型。這個Type類繼承自window是一個Global類型,不屬于任何命名空間。下面我們來看看Type中的一些基本方法以及是怎樣實一些方法的實現(xiàn)方式...

    在認識Type類之前,我們首先要來看一看一個很重要的對象,那就是Function對象。Function對象是JavaScript的內(nèi)部對象,例如:日期對象(Date),數(shù)組對象(Array),字符對象(String)以及(Object,RegExp,Math,Error等)都屬于這種,可以通過new來實例化一個對象。除了我們常見的JavaScript申明的函數(shù),我們也可以用以下的方法構建我們的函數(shù)對象:var myFunction=new Function(arguments,statement)。由于我對腳本不是很熟悉,對prototype(不過聽說是通過給出一個原型對象來指明所要創(chuàng)建的對象的類型,然后用這個原型對象的方法創(chuàng)建出更多同類型的對象,原始模型模式屬于對象的創(chuàng)建模式)也不是很了解,不過經(jīng)過我簡單的測試了一下,如果對Function進行prototype擴展可以通過new來申明對象后再引用他,也可以直接調用Function.(方法或函數(shù))。如果直接運用Function.uName來擴展這個uName就只能通過Function.uName調用,這讓我想起了.NET中的靜態(tài)方法(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中的靜態(tài)對象來調用,如果用new Function();再來調用就會得到"undefined";可能這是JavaScript最基本的東西,但是我以前沒有用過這種對象來寫過腳本,也沒有系統(tǒng)的學過JavaScript,所以不要笑話我哦:)正在學習中...),在上面我還發(fā)現(xiàn)了一個比較少見的call/apply;網(wǎng)上搜了一下發(fā)現(xiàn)在<<全面理解javascript的caller,callee,call,apply概念>>有比較詳細的介紹。如果我沒猜錯的話:Function.createCallback("callback method","callback argument")和回調有關;Function.createDelegate("object通常用this","執(zhí)行的方法"),即通過Function.createDelegate創(chuàng)建的代理方法繼承了b方法,從而來完成整個代理的過程(不知道是否正確!);Function.emptyFunction/Function.emptyMethod應該是為了接口和虛函數(shù)而準備的。

    Type對象繼承了Function對象,由Function對象進一步延伸,在這里我們就不討論Type地實現(xiàn)過程,我們今天主要來看看Type中的一些重要的方法。Type中總共有22個方法,下面我們將逐個進行介紹:

    .[prototype]Type.callBaseMethod(instance,name,baseArguments)
    說明:
       這個函數(shù)主要調用基函數(shù)中的方法,相當于C#中的base;這個函數(shù)只有在繼承函數(shù)時才會用到。
    參數(shù):
       instance:將要被調用的基函數(shù)的當前實例,通常用this;
       name:將要被調用的基函數(shù)的名稱,用字符串表示;
       baseArguments:將要被調用的基函數(shù)的參數(shù)。

    .[prototype]Type.getBaseMethod(instance,name)
    說明:
       引用基函數(shù)的方法實例,如果你要通過Function.call函數(shù)來調用一個方法,這將是你的選擇;不過我覺得和上一個函數(shù)的差別不是特別大,糊涂了。
    參數(shù):
       instance:在這個函數(shù)中好像沒有被調用,上一個函數(shù)的實現(xiàn)是通過這個函數(shù)來獲取函數(shù)的,可能這個參數(shù)是為1中的instance參數(shù)預留的,我也搞不懂他們?yōu)槭裁催@樣干,高手自由高手的道理吧!
       name:當然是所要引用的方法的名稱。

    .[prototype]Type.getBaseType()
    說明:
        其實就是返回"typeof this.__baseType"的值,如果是"undefined"則返回null。

    .[prototype]Type.getInterfaces()
    說明:
        通過這個可以獲取當前實例所實現(xiàn)的接口對象數(shù)組,為一個Array對象。

    .[prototype]Type.getName()
    說明:
        返回當前對象的名稱,包括命名空間和類名稱,如果為"undefined"返回""。

    .[prototype]Type.implementsInterface(interfaceType)
    說明:
        如果當前類已經(jīng)實現(xiàn)了interfaceType接口中的所有定義,則返回true,否則返回false。這也就可以實現(xiàn)在.NET中繼承借口必須實現(xiàn)所有方法或屬性的諾言:)

    .[prototype]Type.inheritsFrom(parentType)
    說明:
        調用此方法可以判斷當前實例是否繼承自parentType類,如:var isInherited=ClassA.inheritsFrom(ClassB);如果當前實例繼承自parentType則返回true,否則返回false。

    .[prototype]Type.initializeBase(instance, baseArguments)
    說明:
        這是一個相當重要的函數(shù),通過這個函數(shù)來初始化基函數(shù)的構造函數(shù),也可以將自己注冊為一個基函數(shù)。其中instance是初始化基類的對象,通常用this;baseArguments為基函數(shù)構造函數(shù)的參數(shù),可以為空。

    .[prototype]Type.isImplementedBy(typeInstance)
    說明:
        這個和6中正好相反,用來判斷typeInstance是否實現(xiàn)了接口中的所有定義,如果是實現(xiàn)返回true,否則返回false。

    .[prototype]Type.isInstanceOfType(instance)
    說明:
        判斷類是否為instance的當前實例,主要用于要判斷類是否為繼承自他的類(子類)的實例。返回true/false。

    .[prototype]Type.registerClass(typeName, baseType, interfaceTypes)
    說明:
        這個一看就知道是注冊一個類的,baseType和interfaceTypes都是可選的,同時和.NET的一樣,baseType最多一個,而接口就無所謂了。這個方法用在定一個類以后初始化之前,如果有baseType須在第一行通過Type.initializeBase來實例化基函數(shù)的構造函數(shù)。

    .[prototype]Type.registerInterface(typeName)
    說明:
        將一個類注冊為接口,接口中部包含任何的處理函數(shù)。

    .[prototype]Type.resolveInheritance()
    說明:
        這個方法很好玩,拷貝基類的屬性,來對當前類進行prototype擴展,可也就是擴展面向對象編程中的反射。

    .Type.getRootNamespaces()
    說明:
        靜態(tài)函數(shù)(我不知道別人怎么叫,我就叫他靜態(tài)函數(shù)就好了:),通過這個方法可以獲取所有命名空間的Array數(shù)組(即返回一個數(shù)組,包含所有命名空間)。

    .Type.isClass(type)
    .Type.isInterface(type)
    .Type.isNamespace(type)

    .Type.parse(typeName,ns)
    說明:
        厲害了,通過這個可以創(chuàng)建一個對象,即.NET中的利用Type.GetType("type,ns");和Invoke();來反射實例化一個類。ns命名空間可選項。如果類沒有位于一個命名空間中(如:Type類),typeName可以為null。

    .Type.registerNamespace(namespacePath)
    說明:
        注冊一個命名空間。

    .[prototype]Type.registerEnum(name,flag)
    說明:
        注冊為枚舉類型,flag判斷是否為bit類型,可選。

    .Type.isEnum(type)
    .Type.isFlags(type)

    寫著寫著胡了,例子還是沒有加上,而且原來的理解好像很模糊,為了讓人能更直觀的理解,我把有些例子放在這里(html文件):


    如果要測試Enum要用<ScriptManager/>空間引用腳本,提供例子里的腳本沒有Number類的擴展,所以不能測試Enum,哎,幾個小時就這樣過去了,不過也掌握了不少,在我寫這篇文章是越來越覺得很模糊,如果有什么錯誤的地方請大家指出,允許Bill Gate先富起來,然后帶動我們富裕,最后實現(xiàn)大家共同富裕嗎:)

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    [ASP.NET AJAX]Function對象及Type類的方法介紹

    [ASP.NET AJAX]Function對象及Type類的方法介紹:上一回我們從總體上認識了JavaScript Microsoft AJAX Library由于臨時有事,沒有加入事例顯得有點抽象,這一回一定會通過一些事例更加直觀的來會一會Asp.NET Ajax腳本庫中一個很是重要的類Type。這個類提供了一些擴展面向對象編程的一些反射方法,通過這個類
    推薦度:
    標簽: 對象 ajax ASP.NET
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 第一福利永久视频精品| 国产精品爽爽va在线观看网站| 人妻少妇精品视中文字幕国语| 99久久www免费人成精品| 精品一区二区三区东京热| 精品国产污污免费网站入口在线| 97久久超碰国产精品旧版| 亚洲精品无码不卡在线播放HE| 精品国精品国产自在久国产应用男| 欧美成人精品一区二区三区| 国产欧美日韩精品a在线观看 | 91精品欧美综合在线观看| 亚洲国产精品一区二区成人片国内| 国产精品亚洲一区二区在线观看| 华人在线精品免费观看| 国内精品久久人妻互换| 久久亚洲私人国产精品| 国产日韩高清三级精品人成| 亚洲AV成人精品日韩一区18p| 91精品国产综合久久香蕉| 国产精品内射后入合集| 久久精品毛片免费观看| 中文字幕精品久久久久人妻| 久久久亚洲精品蜜桃臀| 久久精品二区| 久久人人超碰精品CAOPOREN| 久久99精品九九九久久婷婷| 精品国精品国产自在久国产应用男| 国产精品手机在线观看你懂的| 久久精品视频免费| 自怕偷自怕亚洲精品| 亚洲午夜久久久精品影院| 四虎精品影院永久在线播放| 亚洲国产精品久久久久婷婷老年| 国产精品亚洲欧美一区麻豆 | 久久激情亚洲精品无码?V| 国产精品成人99久久久久91gav| 91国内揄拍国内精品对白不卡| 日韩精品www| 国产精品欧美亚洲韩国日本久久 | 99国产精品私拍pans大尺度|