javascript面向对象之二 命名空间


Posted in Javascript onFebruary 08, 2011

最简单创建命名空间的方法:

var java = {}; 
java.util = {}; 
//这样就创建成功了命名空间:java.util 
//我们可以在java.util下面加类(函数),属性,或对象 
java.util.HashMap = function() 
{ 
this.ShowMessage = function() 
{ 
alert("java.util.HashMap"); 
} 
} 
var map = new java.util.HashMap(); 
alert(map.ShowMessage()); //显示结果:java.util.HashMap

//封装创建命名空间的方法:
//定义一个对象,js中用{}花括号定义对象,等同于 var JsObject = new Object();


var JsObject = {}; 
JsObject.namespace = function() //在JsObject对象下定义一个函数namespace 
{ 
 /*下面代码中arguments为函数传入的参数,在function未明确定义参数时, 
function也可以传入参数,并用arguments来 接收,arguments类似数组, 

如果传入多个参数,将按顺序保存,取值法:arguments[0],arguments[1]....*/ 
var a = arguments,o = null,d,rt; 
for(var i = 0; i < a.length; i++) 
{ 
d = a[i].split('.'); //将传入的参数用符号'.' 进行分割,并放入d数组中。 
rt = d[0]; 
//判断数组中的第一个值是否未定义,如果未定义,便定义为空对象{},并赋值给变量o 
eval('if (typeof ' + rt + ' == "undefined"){' 



+ rt + ' = {};} o = ' + rt + ';'); 

for(var j = 1; j < d.length; j++) 

{ 


/*循环遍历数组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中的变量,并赋予初值,但此变量的访问权限是public 
this.studentNo = 's001'; 
this.studentName = '小明'; 
this.sex = '男'; 
} 
var s = new org.myJs.Student(); //创建Student类的对象 
alert('学号:'+s.studentNo); 
alert('姓名:'+s.studentName); 
alert('性别:'+s.sex);

效果和第一篇 (一)javascript经验总结面向对象—类 结果一样
Javascript 相关文章推荐
鼠标移动到一张图片时变为另一张图片
Dec 05 Javascript
Sample script that displays all of the users in a given SQL Server DB
Jun 16 Javascript
javascript 表格排序和表头浮动效果(扩展SortTable)
Apr 07 Javascript
js中return false(阻止)的用法
Aug 14 Javascript
简单的js图片轮换代码(js图片轮播)
May 06 Javascript
jQuery+AJAX实现遮罩层登录验证界面(附源码)
Sep 13 Javascript
jQuery+CSS3实现3D立方体旋转效果
Nov 10 Javascript
Javascript中的对象和原型(二)
Aug 12 Javascript
Vue数据驱动模拟实现3
Jan 11 Javascript
微信小程序 flex实现导航实例详解
Apr 26 Javascript
基于JavaScript实现弹幕特效
Aug 27 Javascript
Vue中定义全局变量与常量的各种方式详解
Aug 23 Javascript
javascript中的对象创建 实例附注释
Feb 08 #Javascript
kmock javascript 单元测试代码
Feb 06 #Javascript
一次失败的jQuery优化尝试小结
Feb 06 #Javascript
DOM_window对象属性之--clipboardData对象操作代码
Feb 03 #Javascript
基于jQuery的自动完成插件
Feb 03 #Javascript
jQuery初学:find()方法及children方法的区别分析
Jan 31 #Javascript
javascript event 事件解析
Jan 31 #Javascript
You might like
PHP时间格式控制符对照表分享
2013/07/23 PHP
PHP中的魔术方法总结和使用实例
2015/05/11 PHP
ThinkPHP3.2框架自带分页功能实现方法示例
2019/05/13 PHP
文本加密解密
2006/06/23 Javascript
asp.net下使用jquery 的ajax+WebService+json 实现无刷新取后台值的实现代码
2010/09/19 Javascript
js实现翻页后保持checkbox选中状态的实现方法
2012/11/03 Javascript
javascript bom是什么及bom和dom的区别
2015/11/26 Javascript
jQuery插件支持同一页面被多次调用
2016/02/14 Javascript
AngularJS上拉加载问题解决方法
2016/05/23 Javascript
JS定时器使用,定时定点,固定时刻,循环执行详解
2016/05/31 Javascript
基于JS实现省市联动效果代码分享
2016/06/06 Javascript
JavaScript中的 attribute 和 jQuery中的 attr 方法浅析
2017/01/04 Javascript
ajax接收后台数据在html页面显示
2017/02/19 Javascript
vue中的适配px2rem示例代码
2018/11/19 Javascript
JavaScript实现美化滑块效果
2019/05/17 Javascript
vue点击当前路由高亮小案例
2019/09/26 Javascript
python虚拟环境 virtualenv的简单使用
2020/01/21 Javascript
three.js 实现露珠滴落动画效果的示例代码
2021/03/01 Javascript
[04:44]DOTA2 2017全国高校联赛视频回顾
2017/08/21 DOTA
[01:00:53]2018DOTA2亚洲邀请赛3月29日 小组赛B组 iG VS Secret
2018/03/30 DOTA
python通过pil将图片转换成黑白效果的方法
2015/03/16 Python
Python实现嵌套列表及字典并按某一元素去重复功能示例
2017/11/30 Python
Python 25行代码实现的RSA算法详解
2018/04/10 Python
Python实现从SQL型数据库读写dataframe型数据的方法【基于pandas】
2019/03/18 Python
CSS3的新特性介绍
2008/10/31 HTML / CSS
HTML5无刷新改变当前url的代码
2017/03/15 HTML / CSS
美特斯邦威官方商城:邦购网
2016/10/13 全球购物
Java平台和其他软件平台有什么不同
2015/06/05 面试题
人力资源部门的主要职能
2014/02/22 职场文书
企业精神口号
2014/06/11 职场文书
领导班子整改措施
2014/10/24 职场文书
护理工作个人总结
2015/03/03 职场文书
生日寿星公答谢词
2015/09/29 职场文书
简单总结SpringMVC拦截器的使用方法
2021/06/28 Java/Android
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
阿里云服务器Ubuntu 20.04上安装Odoo 15
2022/05/20 Servers