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

一个傻瓜897

一个傻瓜897

2016-02-19 09:20

岁数大了,QQ也不闪了,微信也不响了,电话也不来了,但是图老师依旧坚持为大家推荐最精彩的内容,下面为大家精心准备的JavaScript 编程引入命名空间的方法与代码,希望大家看完后能赶快学习起来。
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 里面就大量使用这种方式,虽然这种方式更直观地像一棵树,但只要节点稍多一些,眼睛就忙于寻找这些节点的关系,命名空间的做法是横向地描述这种关系树,层次关系直接表现在字面上,两种方式效果一致,但书写风格却各有特点。

再扩展一个方法:

NameSpace.prototype.appendChild = function(ns){
for (var key in ns){
this[key] = ns[key];
}
return this;
}
NameSpace.prototype.copyChild = NameSpace.prototype.appendChild;


展开更多 50%)
分享

猜你喜欢

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

Web开发
JavaScript 编程引入命名空间的方法与代码

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

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

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

在JavaScript中实现命名空间

Web开发
在JavaScript中实现命名空间

JavaScript与函数式编程

Web开发
JavaScript与函数式编程

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

java 命名空间 命名规则

编程语言 网络编程
java 命名空间 命名规则

解读HTML:命名空间与字符编码

Web开发
解读HTML:命名空间与字符编码

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

基于c++中的默认拷贝函数的使用详解

基于c++中的默认拷贝函数的使用详解

存储过程解密(破解函数,过程,触发器,视图.仅限于SQLSERVER2000)

存储过程解密(破解函数,过程,触发器,视图.仅限于SQLSERVER2000)
下拉加载更多内容 ↓