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偷钱流符文搭配推荐

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

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

java 命名空间 命名规则

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

lolAD刺客新符文搭配推荐

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

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

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

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

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