四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费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 編程引入命名空間的方法與代碼,轉載需保留來源!

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

主站蜘蛛池模板: 陈雨田| 黑木美纱| 狂野鸳鸯| 唐人街探案网剧1| 五行字库查询表| 女女床戏| 苏州标志性建筑大裤衩| 3d欧美怪物sexvideo| 民国往事电视剧演员表| 感谢有你简谱| 樊城电影| 孔令辉简历及个人资料| 张国立个人资料简介| 乙亥北行日记| 免费看黄在线看| 摘抄现代诗| 赫伯曼电影免费观看| 含羞草传媒2024| 色黄视频免费观看| 官网移动端充值| 第一财经直播电视直播| 上香香灰打卷图解| 徐少强全部电影| 欧美xxxx做受性欧美蜜臀av| cctv17农业农村频道在线直播| 工业硫酸| 大班生字表| 尹海英| 艳堂| 五年级上册白鹭笔记| 《战长沙》电视剧| 被主人调教| 2025最火蛋糕图片| 长谷川清| 肉丸3| 骆文博| 昆虫总动员2免费观看完整版| 肉丸3| 戚薇夫妇现身机场| 无声真相电影免费观看| 汤姆·威尔金森|