javascript面向?qū)ο笾?命名空間
更新時間:2011年02月08日 23:09:38 作者:
javascript中本沒有命名空間的概念,但是要體現(xiàn)面向?qū)ο蟮乃枷耄瑧?yīng)當(dāng)有命名空間,就像java中的package,.net中的namespace一樣,作用主要為了防止類名沖突,相同的類名只要屬于不同的命名空間,便不會沖突。
最簡單創(chuàng)建命名空間的方法:
var java = {};
java.util = {};
//這樣就創(chuàng)建成功了命名空間:java.util
//我們可以在java.util下面加類(函數(shù)),屬性,或?qū)ο?
java.util.HashMap = function()
{
this.ShowMessage = function()
{
alert("java.util.HashMap");
}
}
var map = new java.util.HashMap();
alert(map.ShowMessage()); //顯示結(jié)果:java.util.HashMap
//封裝創(chuàng)建命名空間的方法:
//定義一個對象,js中用{}花括號定義對象,等同于 var JsObject = new Object();
var JsObject = {};
JsObject.namespace = function() //在JsObject對象下定義一個函數(shù)namespace
{
/*下面代碼中arguments為函數(shù)傳入的參數(shù),在function未明確定義參數(shù)時,
function也可以傳入?yún)?shù),并用arguments來 接收,arguments類似數(shù)組,
如果傳入多個參數(shù),將按順序保存,取值法:arguments[0],arguments[1]....*/
var a = arguments,o = null,d,rt;
for(var i = 0; i < a.length; i++)
{
d = a[i].split('.'); //將傳入的參數(shù)用符號'.' 進行分割,并放入d數(shù)組中。
rt = d[0];
//判斷數(shù)組中的第一個值是否未定義,如果未定義,便定義為空對象{},并賦值給變量o
eval('if (typeof ' + rt + ' == "undefined"){'
+ rt + ' = {};} o = ' + rt + ';');
for(var j = 1; j < d.length; j++)
{
/*循環(huán)遍歷數(shù)組d每個值作為key,加入到對象o中,如果key在o中存在,則取o中值,若
不存在,則賦值為空對象{} */
o[d[j]] = o[d[j]] || {};
o = o[d[j]];
}
}
}
JsObject.namespace("org.myJs"); //申明命名空間:org.myJs
org.myJs.Student = function() //在命名空間org.myJs下定義類Student
{
//定義類Student中的變量,并賦予初值,但此變量的訪問權(quán)限是public
this.studentNo = 's001';
this.studentName = '小明';
this.sex = '男';
}
var s = new org.myJs.Student(); //創(chuàng)建Student類的對象
alert('學(xué)號:'+s.studentNo);
alert('姓名:'+s.studentName);
alert('性別:'+s.sex);
效果和第一篇 (一)javascript經(jīng)驗總結(jié)面向?qū)ο蟆?結(jié)果一樣
復(fù)制代碼 代碼如下:
var java = {};
java.util = {};
//這樣就創(chuàng)建成功了命名空間:java.util
//我們可以在java.util下面加類(函數(shù)),屬性,或?qū)ο?
java.util.HashMap = function()
{
this.ShowMessage = function()
{
alert("java.util.HashMap");
}
}
var map = new java.util.HashMap();
alert(map.ShowMessage()); //顯示結(jié)果:java.util.HashMap
//封裝創(chuàng)建命名空間的方法:
//定義一個對象,js中用{}花括號定義對象,等同于 var JsObject = new Object();
復(fù)制代碼 代碼如下:
var JsObject = {};
JsObject.namespace = function() //在JsObject對象下定義一個函數(shù)namespace
{
/*下面代碼中arguments為函數(shù)傳入的參數(shù),在function未明確定義參數(shù)時,
function也可以傳入?yún)?shù),并用arguments來 接收,arguments類似數(shù)組,
如果傳入多個參數(shù),將按順序保存,取值法:arguments[0],arguments[1]....*/
var a = arguments,o = null,d,rt;
for(var i = 0; i < a.length; i++)
{
d = a[i].split('.'); //將傳入的參數(shù)用符號'.' 進行分割,并放入d數(shù)組中。
rt = d[0];
//判斷數(shù)組中的第一個值是否未定義,如果未定義,便定義為空對象{},并賦值給變量o
eval('if (typeof ' + rt + ' == "undefined"){'
+ rt + ' = {};} o = ' + rt + ';');
for(var j = 1; j < d.length; j++)
{
/*循環(huán)遍歷數(shù)組d每個值作為key,加入到對象o中,如果key在o中存在,則取o中值,若
不存在,則賦值為空對象{} */
o[d[j]] = o[d[j]] || {};
o = o[d[j]];
}
}
}
JsObject.namespace("org.myJs"); //申明命名空間:org.myJs
org.myJs.Student = function() //在命名空間org.myJs下定義類Student
{
//定義類Student中的變量,并賦予初值,但此變量的訪問權(quán)限是public
this.studentNo = 's001';
this.studentName = '小明';
this.sex = '男';
}
var s = new org.myJs.Student(); //創(chuàng)建Student類的對象
alert('學(xué)號:'+s.studentNo);
alert('姓名:'+s.studentName);
alert('性別:'+s.sex);
效果和第一篇 (一)javascript經(jīng)驗總結(jié)面向?qū)ο蟆?結(jié)果一樣
相關(guān)文章
面向?qū)ο蟮腏avascript之二(接口實現(xiàn)介紹)
接口是面向?qū)ο驤avascript工具箱中最有用的特性之一。我們都知道GOF在設(shè)計模式中說到:面向接口編程,而非面向?qū)崿F(xiàn)編程2012-01-01Javascript 類與靜態(tài)類的實現(xiàn)
在Javascript里,對面向?qū)ο蟛]有一個直接的實現(xiàn),對于代碼方面也是非常的靈活。2010-04-04從面試題學(xué)習(xí)Javascript 面向?qū)ο螅▌?chuàng)建對象)
從面試題學(xué)習(xí)Javascript 面向?qū)ο螅▌?chuàng)建對象),學(xué)習(xí)js的朋友可以參考下2012-03-03JavaScript面向?qū)ο笤O(shè)計二 構(gòu)造函數(shù)模式
在Javascript面向?qū)ο笤O(shè)計一——工廠模式 中介紹了使用CreateEmployee()函數(shù)創(chuàng)建員工類。ECMAScript中的構(gòu)造函數(shù)可以用來創(chuàng)建特定類型的對象,如Object和Array這樣的原生構(gòu)造函數(shù),在運行時會自動出現(xiàn)在執(zhí)行環(huán)境中,此外也可以創(chuàng)建自定義的構(gòu)造函數(shù),從而創(chuàng)建自定義對象類型的屬性和方法2011-12-12