|
Javascript 本身沒(méi)有命名空間的概念,需要用對(duì)象模擬出來(lái)。
比如定義一個(gè)命名空間的類,用于創(chuàng)建命名空間:
function NameSpace(){
}
這是一個(gè)構(gòu)造函數(shù),但卻不做任何事情,再來(lái)下面和評(píng)論有關(guān)的代碼:
var comment = new NameSpace();
comment.list = function(){/*code...*/};
comment.counter = 0;
第一行創(chuàng)建所謂命名空間(其實(shí)就是一個(gè)空白對(duì)象),名為comment,第二、三行定義該空間下的兩個(gè)方法。調(diào)用時(shí)可以使用 comment.list() 或者 comment.counter++ 等;
再創(chuàng)建子命名空間:
comment.add = new NameSpace();
comment.add.post = function(){/*code...*/}
comment.add.check = function(){}
之所以引入命名空間的概念,是為了避免函數(shù)名相同的問(wèn)題。上面的過(guò)程也可以這樣定義:
var comment = {
list : function(){/*code...*/},
add : {
post : function(){/*code...*/},
check : function(){/*code...*/}
}
}
prototype.js 里面就大量使用這種方式,雖然這種方式更直觀地像一棵樹(shù),但只要節(jié)點(diǎn)稍多一些,眼睛就忙于尋找這些節(jié)點(diǎn)的關(guān)系,命名空間的做法是橫向地描述這種關(guān)系樹(shù),層次關(guān)系直接表現(xiàn)在字面上,兩種方式效果一致,但書(shū)寫(xiě)風(fēng)格卻各有特點(diǎn)。
再擴(kuò)展一個(gè)方法:
NameSpace.prototype.appendChild = function(ns){
for (var key in ns){
this[key] = ns[key];
}
return this;
}
NameSpace.prototype.copyChild = NameSpace.prototype.appendChild;
JavaScript技術(shù):JavaScript 編程引入命名空間的方法與代碼,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。