這篇文章主要講解了“Javascript中面向?qū)ο蟪绦蛟O(shè)計(jì)對象成員的方法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Javascript中面向?qū)ο蟪绦蛟O(shè)計(jì)對象成員的方法”吧!
目前成都創(chuàng)新互聯(lián)已為上千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁空間、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、金口河網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
1.公有成員
我們都知道,在javascript里,萬物皆對象,因此定義一個(gè)對象和公有成員最簡單不過了:
var obj = { aa:"I'm public" }
但是這個(gè)對象只是一個(gè)空殼,不論在java還是C++/C#中對象都是有構(gòu)造函數(shù)的,怎么能讓定義對象的時(shí)候,同時(shí)定義他的構(gòu)造函數(shù)呢?在java/C++中,構(gòu)造函數(shù)其實(shí)是對象的一個(gè)成員函數(shù),但是在javascript中我們要換一種思維,如果僅僅定義構(gòu)造函數(shù):
var obj = { aa:"I'm public", _construct:function(){ } }
我們在new這個(gè)對象的時(shí)候,構(gòu)造函數(shù)是不會(huì)“自動(dòng)”執(zhí)行的,所以想想之前說到的“萬物皆對象”,如何讓一個(gè)對象在定義的時(shí)候執(zhí)行一個(gè)函數(shù)呢?那就是定義一個(gè)函數(shù)對象:)
var obj = function(mem1){ this.aa = mem1; };
這樣我們就定義了一個(gè)具有“構(gòu)造函數(shù)”的對象了
2.公有方法
定義公有方法的方式和定義公有成員的方式一樣,只不過這個(gè)成員是一個(gè)函數(shù),而不是一個(gè)string或者其他類型的對象
var obj = fucntion(mem1){ this.a = mem1; this.getA = function(){ return this.a; } };
3.私有成員和私有方法
我們知道雖然javascript中有對象的概念,但是卻沒有“私有”的概念,也就是說我們不能像java/C++一樣使用關(guān)鍵詞private來定義一個(gè)私有成員,只要是成員,就是公有的,那么怎么實(shí)現(xiàn)私有成員呢?我們首先考慮這個(gè)問題:什么叫私有成員?私有成員就是在對象的外部不能直接訪問的成員,比如對象obj,如果我們能直接引用obj.a那么他就是公有的,如果引用obj._b,提示錯(cuò)誤或者拋出異常,那么_b就是私有的。實(shí)現(xiàn)私有成員也就是實(shí)現(xiàn)在類的外部不能訪問他的某種成員,而只能通過他的成員函數(shù)訪問。在1中已經(jīng)說了,我們現(xiàn)在定義的是函數(shù)對象,那么也就是說要實(shí)現(xiàn)在函數(shù)的外部不能訪問他的某種成員,而只能通過他的成員函數(shù)訪問。函數(shù)的成員函數(shù)這叫什么話?我們換一種說法:函數(shù)內(nèi)部定義的函數(shù)。那么我們要實(shí)現(xiàn)的就是在函數(shù)的外部不能訪問,但是在函數(shù)內(nèi)部定義的函數(shù)能訪問的某種變量,如果了解javascript特性的開發(fā)人員,應(yīng)該對黑體的這句話感覺似曾相識,沒錯(cuò),這就是閉包的概念。
關(guān)于閉包的概念在這兒就不解釋了,這個(gè)概念可以當(dāng)作一個(gè)專題來講了,太復(fù)雜了,可以看看《javascript高級編程》或者google之。
有了上面的想法,就可以改造一下上面的對象定義。
var obj = function(){ //private member var _b; //public member this.a = mem1; //constructor _b = mem2; //private method definations function _getB(){return _b}; //public method definations this.getA = function(){return this.a;}; this.getB = function(){return _getB();}; this.setA = fucntion(){……}; this.setB = fucntion(){……}; }
由于局部變量_b是在函數(shù)作用域定義的,因此在函數(shù)對象外部無法訪問,同樣“局部”函數(shù)_getB也是在函數(shù)作用域中定義的,也無法在函數(shù)對象外部訪問,但是同是在函數(shù)作用域定義的函數(shù)getA和getB由于閉包的作用,即使對象(函數(shù))定義時(shí),對象(函數(shù))的代碼執(zhí)行完了(即離開局部作用域),依然能夠訪問局部變量(成員)_b和局部變量(函數(shù))_getB,從而實(shí)現(xiàn)了私有成員和私有函數(shù)。
4.靜態(tài)變量和靜態(tài)函數(shù)
沒錯(cuò),是“靜態(tài)變量和靜態(tài)函數(shù)”,當(dāng)我看到這里的時(shí)候也很驚訝,閉包實(shí)現(xiàn)私有也就算了,怎么還要搞出來一個(gè)靜態(tài)變量和靜態(tài)函數(shù)?熟悉javascript的都知道原型(prototype)的概念,在我看來,其實(shí)原型類似于類屬性和類方法,但是他在運(yùn)行期是可以任意改變的,這里再介紹一下javascript中實(shí)現(xiàn)靜態(tài)變量和靜態(tài)函數(shù)
在私有成員和私有方法中,介紹了可以用閉包來實(shí)現(xiàn)將“成員”定義在函數(shù)作用域中,從而限制其訪問,那么如何實(shí)現(xiàn)所有對象共享的成員和函數(shù)呢?所謂的所有對象共享,換一種思路其實(shí)就是這種成員的作用域和其他成員的作用域不同,還是考慮閉包的概念,我們在私有成員和私有方法中定義的對象,對象定義時(shí)他的作用域其實(shí)就是整個(gè)函數(shù)作用域,在函數(shù)中定義所有內(nèi)容在new的時(shí)候都會(huì)執(zhí)行一遍,那怎么做才能讓對象在new的時(shí)候其靜態(tài)成員和靜態(tài)函數(shù)不再被定義呢?別忘了,我們在定義對象的時(shí)候他還是個(gè)函數(shù),我們寫了這么多函數(shù),為啥沒寫return呢?因?yàn)槲覀円恢卑阉?dāng)對象來用,改把人家當(dāng)成函數(shù)看了吧,如果我們再return一個(gè)對象的話,那么在new的時(shí)候,就只會(huì)new我們r(jià)eturn的對象了,因此,在外層函數(shù)定義的內(nèi)容只在定義的時(shí)候執(zhí)行,在new的時(shí)候就不再執(zhí)行了。有人又問了,那我們的對象就不再是外層函數(shù)對象了,在他里面定義的內(nèi)容咋用?。縿e忘了“閉包”這個(gè)概念,return的函數(shù)也是在(外層)函數(shù)作用域內(nèi)定義的函數(shù),他“有權(quán)”訪問外層函數(shù)定義的內(nèi)容,因此,靜態(tài)變量和靜態(tài)函數(shù)的定義如下:
var obj = (function(){ //static attribute var obj_num = 0; //static method function add(){obj_num++}; return function(mem1){ this.a = mem1; this.func = function(){}; //blow you can write some constructor codes } })();//最早看到這一行我就頭大,現(xiàn)在看起來是多么的藝術(shù)啊^_^
通常靜態(tài)方法的時(shí)候都是私有的,如果想定義公有的靜態(tài)方法,可以加上:
obj.pubmethod = function(){ };
5.常量
什么是常量?常量就是對象中不能改變的量,什么又叫對象中不能改變的量?就是說無論在對象內(nèi)部還是外部都不能改變的量,私有變量本身在外部無法改變,內(nèi)部無法改變的話也就是沒有一個(gè)能改變其值的函數(shù)即可^_^
感謝各位的閱讀,以上就是“Javascript中面向?qū)ο蟪绦蛟O(shè)計(jì)對象成員的方法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Javascript中面向?qū)ο蟪绦蛟O(shè)計(jì)對象成員的方法這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!