使用過Java、C#的同學對命名空間非常的熟悉,在複雜的系統中會有N多的函數、對象,語言提供的、架構預定義的,這麼多的函數和對象,由於程式設計規範要求起有實際意義的名字,難免會重名發生錯誤調用,而有了命名空間煩惱就沒有了,不但可以分類組織函數與對象,還可以形成隔離,解決重名問題。
使用JavaScript就沒有這麼舒服了,Javascript只有函數作用域,什麼塊兒啊、神馬文件啊統統都認為是一個命名空間的,有時因為一些重名問題導致的錯誤讓人莫名其妙,難以調試解決。
一個簡單的例子
JavaScript有函數的作用域,可以利用這點把自訂的函數寫到一個函數體內,這樣函數內的變數、物件、函數就像在一個命名空間內一樣和外部隔離。
複製程式碼
程式碼如下:
}複製程式碼
程式碼如下:
複製程式碼
}
xxx();
美化一下
上面的寫法看起來不錯了,但是函數名稱namespace似乎是多餘的了,可以美化一下
複製碼
複製程式碼
程式碼如下:
var length=obj.length;
return true;
}
_NS.prototype.html = function (obj,value) {
if (typeof value == 'string') {
obj.innerHTML = value;
var length = obj.length;
while (i obj[i].innerHTML = value;
i = 1;
}
} else {
if (!isArray) {
return obj.innerHTML;
} else {
return obj[0].innerHTML;
}
}
}
window.NS = new _NS();
})();
這樣一個有命名空間的簡單JavaScript庫就寫成了,不用擔心命名衝突了,但是用起來很不方便啊,做前端的同學都用過jQuery,人家用起來那叫一個簡單,jQuery是怎麼做的?欲知後事如何,且聽下回分解。