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 相关文章推荐
如何在Mozilla Gecko 用Javascript加载XSL
Jan 09 Javascript
Javascript下的keyCode键码值表
Apr 10 Javascript
JQuery通过Ajax提交表单并返回结果
Jul 31 Javascript
jquery jqPlot API 中文使用教程(非常强大的图表工具)
Aug 15 Javascript
8个实用的jQuery技巧
Mar 04 Javascript
Javascript中的默认参数详解
Oct 22 Javascript
javascript实现图片循环渐显播放的方法
Feb 24 Javascript
在Ubuntu系统上安装Node.JS的教程
Oct 15 Javascript
jQuery自定义数值抽奖活动代码
Jun 11 Javascript
Javascript将字符串日期格式化为yyyy-mm-dd的方法
Oct 27 Javascript
Vue.js 利用v-for中的index值实现隔行变色
Aug 01 Javascript
angular6开发steps步骤条组件
Jul 04 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
PHP 向右侧拉菜单实现代码,测试使用中
2009/11/03 PHP
destoon在各个服务器下设置URL Rewrite(伪静态)的方法
2014/06/21 Servers
PHP实现检测客户端是否使用代理服务器及其匿名级别
2015/01/07 PHP
Laravel 框架控制器 Controller原理与用法实例分析
2020/04/14 PHP
教你如何解密js/vbs/vbscript加密的编码异处理小结
2008/06/25 Javascript
Jquery 1.42 checkbox 全选和反选代码
2010/03/27 Javascript
jQuery load方法用法集锦
2011/12/06 Javascript
js导出格式化的excel 实例方法
2013/07/17 Javascript
node.js中的fs.chmod方法使用说明
2014/12/18 Javascript
简介AngularJS中使用factory和service的方法
2015/06/17 Javascript
jquery简单插件制作(fn.extend)完整实例
2016/05/24 Javascript
js复制内容到剪贴板代码,js复制代码的简单实例
2016/10/27 Javascript
JavaScript基本类型值-Number类型
2017/02/24 Javascript
ES6之模版字符串的具体使用
2018/05/17 Javascript
快速解决vue动态绑定多个class的官方实例语法无效的问题
2018/09/05 Javascript
[04:59]DOTA2-DPC中国联赛 正赛 Ehome vs iG 选手采访
2021/03/11 DOTA
Python实现获取nginx服务器ip及流量统计信息功能示例
2018/05/18 Python
python实现简单名片管理系统
2018/11/30 Python
python调用matlab的m自定义函数方法
2019/02/18 Python
Python文件操作中进行字符串替换的方法(保存到新文件/当前文件)
2019/06/28 Python
python selenium爬取斗鱼所有直播房间信息过程详解
2019/08/09 Python
numpy数组做图片拼接的实现(concatenate、vstack、hstack)
2019/11/08 Python
完美解决python针对hdfs上传和下载的问题
2020/06/05 Python
Python绘图之柱形图绘制详解
2020/07/28 Python
Pytorch如何切换 cpu和gpu的使用详解
2021/03/01 Python
HTML5学习笔记之html5与传统html区别
2016/01/06 HTML / CSS
耐克奥地利官网:Nike奥地利
2019/08/16 全球购物
实验教师岗位职责
2014/02/13 职场文书
揭牌仪式主持词
2014/03/19 职场文书
感恩之星事迹材料
2014/05/03 职场文书
九一八事变演讲稿
2014/09/05 职场文书
法制教育演讲稿
2014/09/10 职场文书
防暑降温通知书
2015/04/27 职场文书
高中同学会致辞
2015/08/01 职场文书
spring cloud eureka 服务启动失败的原因分析及解决方法
2022/03/17 Java/Android
Pytorch中使用ImageFolder读取数据集时忽略特定文件
2022/03/23 Python