国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-21 01:58:59
字體:
來源:轉載
供稿:網友
JavaScript 代碼一般最常見的語法格式就是定義函數 function xxx(){/*code...*/},經常有這樣的一大堆函數定義。函數名很容易發生沖突,特別是引入多個js文件時,沖突的情況尤為明顯。因此也就有引入命名空間的必要。
Javascript 本身沒有命名空間的概念,需要用對象模擬出來。
比如定義一個命名空間的類,用于創建命名空間:

function NameSpace(){
}

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

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

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

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

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

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

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

再擴展一個方法:

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 汉阴县| 淮滨县| 灵山县| 淅川县| 商洛市| 广德县| 额尔古纳市| 定州市| 泸州市| 闻喜县| 鄂伦春自治旗| 德化县| 毕节市| 白银市| 彰化市| 棋牌| 托里县| 庆城县| 汤原县| 遵义县| 黑山县| 抚州市| 连平县| 右玉县| 渭南市| 靖州| 定南县| 利川市| 双峰县| 佛坪县| 海门市| 德清县| 嘉兴市| 鹿邑县| 濉溪县| 商南县| 腾冲县| 朔州市| 泰来县| 泗阳县| 漳浦县|