javascript创建命名空间的5种写法
来源: 阅读:905 次 日期:2014-07-30 17:34:19
温馨提示: 小编为您整理了“javascript创建命名空间的5种写法”,方便广大网友查阅!

在javascript中全局变量经常会引起命名冲突,甚至有时侯重写变量也不是按照你想像中的顺序来的,可以看看下面的例子:

代码如下:

var sayhello = function() {

  return 'hello var';

};

>function sayhello(name) {

  return 'hello function';

};

>sayhello();

最终的输出为

代码如下:

> hello var

为什么会这样,根据 stackoverflow 的解释,实际上javascript的是按如下顺序解析的。

代码如下:

function sayhello(name) {

  return 'hello function';

};

var sayhello = function() {

  return 'hello var';

};

sayhello();

不带var的function声明被提前解析了,因此现代的js写法建议你始终使用前置var声明所有变量;

避免全局变量名冲突的最好办法还是创建命名空间,下面是在js中合建命名空间的几种常用方法。

一、通过函数(function)创建

这是一种比较常见的写法,通过声明一个function实现,函数里设置初始变量,公共方法写入prototype,如:

代码如下:

var namespace = namespace || {};

/*

function

*/

namespace.hello = function() {

  this.name = 'world';

};

namespace.hello.prototype.sayhello = function(_name) {

  return 'hello ' + (_name || this.name);

};

var hello = new namespace.hello();

hello.sayhello();

这种写法比较冗长,不利于压缩代码(jquery使用fn代替prototype),而且调用前需要先实例化(new)。使用object写成json形式可以写得紧凑些:

二、通过json对象创建object

代码如下:

/*

object

*/

var namespace = namespace || {};

namespace.hello = {

    name: 'world'

  , sayhello: function(_name) {

    return 'hello ' + (_name || this.name);

  }

};

调用

代码如下:

namespace.hello.sayhello('js');

> hello js;

这种写法比较紧凑,缺点是所有变量都必须声明为公有(public)的,导致所有对这些变量的引用都需要加this指示作用域,写法也略有冗余。

三、通过闭包(closure)和object实现

在闭包中声明好所有变量和方法,并通过一个json object返回公有接口:

代码如下:

var namespace = namespace || {};

namespace.hello = (function() {

  //待返回的公有对象

  var self = {};

  //私有变量或方法

  var name = 'world';

  //公有方法或变量

  self.sayhello = function(_name) {

    return 'hello ' + (_name || name);

  };

  //返回的公有对象

  return self;

}());

四、object和闭包的改进型写法

上个例子在内部对公有方法的调用也需要添加self,如:self.sayhello(); 这里可以最后再返回所有公有接口(方法/变量)的json对象。

代码如下:

var namespace = namespace || {};

namespace.hello = (function() {

  var name = 'world';

  var sayhello = function(_name) {

    return 'hello ' + (_name || name);

  };

  return {

    sayhello: sayhello

  };

}());

五、function的简洁写法

这是一种比较简洁的实现,结构紧凑,通过function实例,且调用时无需实例化(new),方案来自stackoverflow:

代码如下:

var namespace = namespace || {};

namespace.hello = new function() {

  var self = this;

  var name = 'world';

  self.sayhello = function(_name) {

    return 'hello ' + (_name || name);

  };

};

欢迎补充。

更多信息请查看IT技术专栏

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map