JavaScript 编程引入命名空间

作者:CNLei 来源:CNLei.blog 时间:2007-10-11 19:00:00 

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,function,命名
0
投稿

猜你喜欢

  • 朋友去一家游戏公司的机试题,被难住了

    2009-11-29 15:23:00
  • Python实现聊天机器人的示例代码

    2022-11-16 18:10:56
  • Python过滤掉numpy.array中非nan数据实例

    2021-08-25 14:47:44
  • 如何利用Matplotlib库绘制动画及保存GIF图片

    2021-06-08 17:15:40
  • oracle中commit之后进行数据回滚的方法

    2024-01-25 01:00:53
  • Python机器学习应用之决策树分类实例详解

    2021-12-19 16:57:53
  • javascript 得到变量类型的函数

    2024-04-30 08:53:34
  • Python实现多张图片合成一张马赛克图片

    2022-02-15 21:09:46
  • Python MD5文件生成码

    2023-01-21 02:41:31
  • asp vbcrlf是什么意思

    2011-03-30 11:03:00
  • DataFrame.to_excel多次写入不同Sheet的实例

    2022-03-26 01:20:14
  • 使用pickle存储数据dump 和 load实例讲解

    2023-05-19 18:50:18
  • Oracle 9i轻松取得建表和索引的DDL语句

    2010-07-16 13:09:00
  • 详细解读Python中的__init__()方法

    2023-03-25 17:10:27
  • 百度在线手写输入法

    2010-02-03 14:27:00
  • Python中def()函数的实战练习题

    2023-02-13 02:04:54
  • 基于python实现Pycharm断点调试

    2021-05-18 03:16:22
  • 基于mysql多实例安装的深入解析

    2024-01-21 01:59:27
  • pycharm 2019 最新激活方式(pycharm破解、激活)

    2021-09-15 13:07:01
  • 关于Python3 lambda函数的深入浅出

    2023-01-12 09:12:41
  • asp之家 网络编程 m.aspxhome.com