中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

JavaScript 編程引入命名空間的方法與代碼

JavaScript 代碼一般最常見的語法格式就是定義函數(shù) function xxx(){/*code...*/},經(jīng)常有這樣的一大堆函數(shù)定義。函數(shù)名很容易發(fā)生沖突,特別是引入多個js文件時,沖突的情況尤為明顯。因此也就有引入命名空間的必要。
Javascript 本身沒有命名空間的概念,需要用對象模擬出來。
比如定義一個命名空間的類,用于創(chuàng)建命名空間:

function NameSpace(){
}

這是一個構造函數(shù),但卻不做任何事情,再來下面和評論有關的代碼:

var comment = new NameSpace();
comment.list = function(){/*code...*/};
comment.counter = 0;

第一行創(chuàng)建所謂命名空間(其實就是一個空白對象),名為comment,第二、三行定義該空間下的兩個方法。調(diào)用時可以使用 comment.list() 或者 comment.counter++ 等;
再創(chuàng)建子命名空間:

comment.add = new NameSpace();
comment.add.post = function(){/*code...*/}
comment.add.check = function(){}

之所以引入命名空間的概念,是為了避免函數(shù)名相同的問題。上面的過程也可以這樣定義:

var comment = {
 list : function(){/*code...*/},
 add  : {
  post  :  function(){/*code...*/},
  check :  function(){/*code...*/}
 }
}

prototype.js 里面就大量使用這種方式,雖然這種方式更直觀地像一棵樹,但只要節(jié)點稍多一些,眼睛就忙于尋找這些節(jié)點的關系,命名空間的做法是橫向地描述這種關系樹,層次關系直接表現(xiàn)在字面上,兩種方式效果一致,但書寫風格卻各有特點。

再擴展一個方法:

NameSpace.prototype.appendChild = function(ns){
for (var key in ns){
this[key] = ns[key];
}
return this;
}
NameSpace.prototype.copyChild = NameSpace.prototype.appendChild;


JavaScript技術JavaScript 編程引入命名空間的方法與代碼,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美黑人一级爽快片淫片高清 | 久久这里有精品 | 日本韩国欧美在线观看 | 国产精品成人国产乱一区 | 美女福利视频网站 | 91传媒在线观看 | av一区二区三区四区 | 国产91av视频在线观看 | 日日干夜夜干 | 久久久久国产一区二区三区 | 一区二区av | 国产在线拍偷自揄拍视频 | 亚洲欧洲在线视频 | 成人在线视频免费看 | 日韩视频一区二区三区 | www.婷婷| 久草福利 | 国产精品成人在线播放 | 亚洲精品一区二区网址 | 日韩中文字幕久久 | 欧美福利精品 | 日日夜夜狠狠操 | 男女午夜免费视频 | 亚洲风情在线观看 | 日韩高清不卡 | 欧美中文字幕一区 | 97精品超碰一区二区三区 | 天天看片天天干 | 欧美精品久久久久 | 国产在线精品一区 | 性一交一乱一透一a级 | 亚洲一区在线播放 | 91久久久久久久久久久 | 99久久99| 中文字幕一区二区三区精彩视频 | 一级做a爰片性色毛片16美国 | 成人在线视频网站 | 成人免费三级电影 | 午夜视频一区二区三区 | 欧美在线视频一区二区 | 久久久久成人精品 |