四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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

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;


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

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

主站蜘蛛池模板: cctv16奥林匹克频道| 网络谜踪 电影| 日本大片ppt免费ppt| 变形记开头结尾优美段落| 吴婷个人资料及照片| 上瘾演员表| 肱骨骨折能评几级伤残| 胡蕾| 首映式| 墨雨云间电视剧| 来生缘吉他谱c调| 星河长明免费观看电视剧| 好看女生头像| 德鲁| 最爱电影完整版在线观看免费高清 | 风云2演员表全部| 喜福会电影| 远方的故乡简谱| 在线观看高清电影| 天国恩仇| 暴风前夜 电影| 员工离职协议书| 电车之狼| 心经全文260字| 邓为个人资料及简历| 驿路梨花思维导图| 雪肌夜叉| 绝顶五秒前在线观看| 色即是空韩国| 服务群众方面整改成效| 红海行动2虎鲸行动| 性感直播| 北风那个吹全集免费观看| 吻船| 新力量电影在线观看免费| 柿柿红红岁岁年电视剧演员表| 流行歌简谱| 张鸣岐| 炊事班的故事演员名单| 局外人电影| 伴生活|