免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
由prototype

還是決定冠上ajax的頭銜,畢竟很多人會(huì)用這個(gè)關(guān)鍵詞搜索。雖然我認(rèn)為這只是個(gè)炒作的概念,不過(guò)不得不承認(rèn)ajax叫起來(lái)要方便多了。所以ajax的意思我就不詳細(xì)解釋了。

寫(xiě)這個(gè)教程的起因很簡(jiǎn)單:經(jīng)過(guò)一段時(shí)間的ajax學(xué)習(xí),有一些體會(huì),并且越發(fā)認(rèn)識(shí)到ajax技術(shù)的強(qiáng)大,所以決定記錄下來(lái),順便也是對(duì)自己思路的整理。有關(guān)這個(gè)教程的后續(xù),請(qǐng)關(guān)注http://www.x2design.net

前幾年,javascript在一般人眼里,功能還很狹窄,所能做的要么是一些簡(jiǎn)單的表單驗(yàn)證,要么是許多華而不實(shí)的網(wǎng)頁(yè)特效。隨著flash的出現(xiàn),大家已經(jīng)不像以前那樣熱衷于js特效。似乎js能做的事情更加少了。但這時(shí)候,ajax的概念冒了出來(lái),以gmail為典型代表的ajax應(yīng)用受到很多人的關(guān)注,ajax一下子成為一種很熱門(mén)的技術(shù),當(dāng)javascript和xml,和dom模型結(jié)合起來(lái),其所能做的事情常常令人匪夷所思,甚至有些功能已經(jīng)可以和桌面程序相當(dāng)。

好了廢話(huà)就不多說(shuō)了,現(xiàn)在就從一個(gè)javascript的開(kāi)發(fā)框架prototype_1.3.1(下面簡(jiǎn)稱(chēng)為prototype)開(kāi)始。我本來(lái)是想先介紹一下javascript的高級(jí)應(yīng)用,但怕水平不夠,說(shuō)的沒(méi)有條理,所以就結(jié)合prototype來(lái)說(shuō),順便會(huì)提及js的語(yǔ)法使用。
下面是框架最前面的兩段代碼:

var Prototype = {
  Version: ‘1.3.1‘,
  emptyFunction: function() {}
}
var Class = {
  create: function() {
    return function() {
      this.initialize.apply(this, arguments);
    }
  }
}

首先,讓我們來(lái)看下面兩個(gè)語(yǔ)法的區(qū)別:

var o={};
var f=function(){};


后面一個(gè)很容易理解,它等價(jià)于function f(){};定義一個(gè)函數(shù)f。但前面一個(gè)就不常見(jiàn)了:這其實(shí)是創(chuàng)建一個(gè)對(duì)象,在{}中可以指定對(duì)象的成員,比如上面的Prototype,就是一個(gè)對(duì)象,有兩個(gè)成員,第一個(gè)是版本號(hào),第二個(gè)是一個(gè)空方法(函數(shù))。像這種不用定義類(lèi),就能直接創(chuàng)建對(duì)象的功能可能只有js能做到。后面一種語(yǔ)法其實(shí)還有一個(gè)功能,就是定義一個(gè)類(lèi)f。如果你在函數(shù)體中用了this,那么this后面的變量就是類(lèi)的成員。
不僅this可以定義類(lèi)成員,還有一種語(yǔ)法:

function c(){
 member1:value,
 member2:function(){}
}


這等價(jià)于:

function c(){
 this.member1=value;
 this.member2=function(){};
}


需要注意的是,用前一種辦法時(shí),最后一個(gè)成員的最后不能加逗號(hào),我想這種語(yǔ)法應(yīng)該和數(shù)組有關(guān)。

在js里,函數(shù)和類(lèi)是沒(méi)有區(qū)別的,都可以new,new的作用是把函數(shù)體的語(yǔ)句都執(zhí)行一遍,然后返回一個(gè)對(duì)象。如果函數(shù)里有this,那么this后面的變量會(huì)作為對(duì)象成員;如果沒(méi)有,那么new的作用只是返回一個(gè)沒(méi)有任何成員的空對(duì)象。所以你用typeof查看一個(gè)所謂類(lèi)的類(lèi)型時(shí),仍然會(huì)返回function。在js里也基本沒(méi)有類(lèi)型的概念,所有變量的聲明都用var,即使是函數(shù),也是如此。函數(shù),其實(shí)也只是一個(gè)變量。

說(shuō)函數(shù)是變量,可能很多人不解。但是你試試下面的做法:

function fTest(){
 var a=1;
 alert(a);
}
alert(fTest);


你會(huì)發(fā)現(xiàn)顯示的是fTest這個(gè)函數(shù)的函數(shù)體,所以我們可以認(rèn)為,所謂函數(shù),僅僅是js引擎可以解析的一段代碼字符串。函數(shù)名變量存儲(chǔ)的只是這個(gè)字符串。說(shuō)的更準(zhǔn)確一點(diǎn),函數(shù)名是一個(gè)指針變量,它存儲(chǔ)的是這個(gè)代碼字符串在內(nèi)存中的位置。這樣就不難理解將函數(shù)作為參數(shù)傳遞,可以作為值返回了,這是以后會(huì)大量使用的技術(shù)。因?yàn)轭?lèi)也是函數(shù),所以理解了函數(shù),也就理解了類(lèi)。

雖然在js里函數(shù)和類(lèi)沒(méi)有區(qū)別,但是類(lèi)的概念卻可以方便我們進(jìn)行程序設(shè)計(jì),于是prototype很有創(chuàng)意的創(chuàng)建了一個(gè)全局對(duì)象Class:

var Class = {
  create: function() {
    return function() {
      this.initialize.apply(this, arguments);
    }
  }
}


Class是一個(gè)全局對(duì)象,它的唯一方法就是create,作用返回一個(gè)函數(shù),前面已經(jīng)講過(guò)函數(shù)作為返回值的機(jī)制,這里不再遨述。返回的函數(shù)包括一條語(yǔ)句:

this.initialize.apply(this, arguments);


前面講過(guò),new一個(gè)函數(shù)時(shí),會(huì)執(zhí)行函數(shù)里的代碼,最后返回對(duì)象。所以當(dāng)使用Class.create()創(chuàng)建了一個(gè)函數(shù),再new這個(gè)返回的函數(shù)時(shí),首先會(huì)執(zhí)行這條語(yǔ)句。后面可以看到,這其實(shí)是為了調(diào)用類(lèi)的構(gòu)造函數(shù)。

就是這樣,Class成為了整個(gè)prototype的類(lèi)型創(chuàng)建模型,并且能很好的把類(lèi)和函數(shù)在代碼上區(qū)分開(kāi)來(lái)。Class.create()僅僅是返回一個(gè)空類(lèi),而且它會(huì)默認(rèn)為這個(gè)類(lèi)是具有initialize方法的,所以要使用這個(gè)類(lèi),至少需要有一個(gè)構(gòu)造函數(shù),這就需要使用到類(lèi)的繼承。類(lèi)只是一個(gè)函數(shù),那么函數(shù)怎么繼承呢?看起來(lái)匪夷所思,javascript能做到這一點(diǎn),prototype使得實(shí)現(xiàn)更為優(yōu)雅,至于它是怎么做到的,且聽(tīng)下回分解。

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶(hù)發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
圖靈社區(qū) : 閱讀 : OOP與jQuery(四):函數(shù)作用域、方法連綴及jQuery.fn
JavaScript模擬命名空間
一周一話(huà)題之四(JavaScript、Dom、jQuery全面復(fù)習(xí)總結(jié)<js篇>)
前端開(kāi)發(fā)面試題之JavaScript
JavaScript 10分鐘入門(mén)
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服