JavaScript 编程引入命名空间的方法


Posted in Javascript onJune 29, 2007

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 里面就大量使用这种方式,虽然这种方式更直观地像一棵树,但只要节点稍多一些,眼睛就忙于寻找这些节点的关系,命名空间的做法是横向地描述这种关系树,层次关系直接表现在字面上,两种方式效果一致,但书写风格却各有特点。

Javascript 相关文章推荐
js弹窗代码 可以指定弹出间隔
Jul 03 Javascript
Jquery 过滤器(first,last,not,even,odd)的使用
Jan 22 Javascript
JS获取及设置TextArea或input文本框选择文本位置的方法
Mar 24 Javascript
javascript实现一个数值加法函数
Jun 26 Javascript
在AngularJS中使用jQuery的zTree插件的方法
Apr 21 Javascript
JS常用算法实现代码
Nov 14 Javascript
微信小程序购物商城系统开发系列-目录结构介绍
Nov 21 Javascript
Javascript 制作图形验证码实例详解
Dec 22 Javascript
jQuery选择器_动力节点Java学院整理
Jul 05 jQuery
[js高手之路]单例模式实现模态框的示例
Sep 01 Javascript
浅谈Emergence.js 检测元素可见性的 js 插件
Nov 18 Javascript
Vue3为什么这么快
Sep 23 Javascript
你需要知道的JavsScript可以做什么?
Jun 29 #Javascript
ECMAScript 基础知识
Jun 29 #Javascript
javascript中的几个运算符
Jun 29 #Javascript
一个加载js文件的小脚本
Jun 28 #Javascript
javascript实现的鼠标链接提示效果生成器代码
Jun 28 #Javascript
用js实现控制内容的向上向下滚动效果
Jun 26 #Javascript
脚本安需导入(装载)的三种模式的对比
Jun 24 #Javascript
You might like
CentOS 安装 PHP5.5+Redis+XDebug+Nginx+MySQL全纪录
2015/03/25 PHP
php实现过滤字符串中的中文和数字实例
2015/07/29 PHP
浅谈PHP eval()函数定义和用法
2016/06/21 PHP
jquery 新浪网易的评论块制作
2010/07/01 Javascript
JS截取字符串常用方法详细整理
2013/10/28 Javascript
javascript相等运算符与等同运算符详细介绍
2013/11/09 Javascript
微信js-sdk分享功能接口常用逻辑封装示例
2016/10/13 Javascript
微信小程序 登录实例详解
2017/01/16 Javascript
JS实现的文字间歇循环滚动效果完整示例
2018/02/13 Javascript
浅析Visual Studio Code断点调试Vue
2018/02/27 Javascript
基于JavaScript实现幸运抽奖页面
2020/07/05 Javascript
Node.js 使用jade模板引擎的示例
2018/05/11 Javascript
Vue.js单向绑定和双向绑定实例分析
2018/08/14 Javascript
JS开发 富文本编辑器TinyMCE详解
2019/07/19 Javascript
关于NodeJS中的循环引用详解
2019/07/23 NodeJs
[01:00]一分钟回顾2018DOTA2亚洲邀请赛现场活动
2018/04/07 DOTA
[49:41]NB vs NAVI Supermajor小组赛A组 BO3 第一场 6.2
2018/06/03 DOTA
30分钟搭建Python的Flask框架并在上面编写第一个应用
2015/03/30 Python
python制作最美应用的爬虫
2015/10/28 Python
Python 读取某个目录下所有的文件实例
2018/06/23 Python
深入解析Python小白学习【操作列表】
2019/03/23 Python
pandas实现to_sql将DataFrame保存到数据库中
2019/07/03 Python
如何基于python实现不邻接植花
2020/05/01 Python
Vita Fede官网:在意大利手工制作,在纽约市设计
2019/10/25 全球购物
.net C#面试题
2012/08/28 面试题
好人好事事迹材料
2014/02/12 职场文书
棉花姑娘教学反思
2014/02/15 职场文书
班主任班级寄语大全
2014/04/04 职场文书
社会体育专业大学生职业生涯规划书
2014/09/17 职场文书
2014年施工员工作总结
2014/11/18 职场文书
党员检讨书范文
2014/12/27 职场文书
2015年银行柜员工作总结报告
2015/04/01 职场文书
大学生求职意向书
2015/05/11 职场文书
工作收入证明范本
2015/06/12 职场文书
高老头读书笔记
2015/06/30 职场文书
MySQL infobright的安装步骤
2021/04/07 MySQL