JavaScript中创建命名空间

引用:http://ourjs.com/detail/538d8d024929582e6200000c
 
在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 = window.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 = window.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 = window.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 = window.NameSpace || {};
NameSpace.Hello = (function() {
  var name = 'world';
  var sayHello = function(_name) {
    return 'Hello ' + (_name || name);
  };
  return {
    sayHello: sayHello
  };
}());
 
Function的简洁写法
 
这是一种比较简洁的实现,结构紧凑,通过function实例,且调用时无需实例化(new),方案来自 stackoverflow
 
var NameSpace = window.NameSpace || {};
NameSpace.Hello = new function() {
  var self = this;
  var name = 'world';
  self.sayHello = function(_name) {
    return 'Hello ' + (_name || name);
  };
};


调用

NameSpace.Hello.sayHello();

转载于:https://www.cnblogs.com/Dylanblogs/p/4893894.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: jQuery 命名空间是一个简称为 "$" 的全局 JavaScript 变量,用于指向 jQuery 对象。通过这个变量,我们可以访问 jQuery 的方法和属性,例如: ``` $(document).ready(function() { // 在文档加载完成后执行代码 }); ``` 在使用 jQuery 的时候,如果你的代码出现了其他 JavaScript 库也使用 "$" 作为全局变量的话,就会发生冲突。为了避免这种情况,jQuery 提供了一个叫做 "noConflict" 的方法,可以将 jQuery 命名空间释放回来,以便其他 JavaScript 库使用。例如: ``` var jq = $.noConflict(); // 现在可以使用 jq 访问 jQuery 对象了 ``` ### 回答2: jQuery命名空间是一种将所有jQuery相关的功能和方法组织起来的方式。通过将所有的jQuery代码放在一个命名空间,可以避免与其他JavaScript库或代码之间的冲突。 使用jQuery命名空间,可以将所有的jQuery代码包装在一个自定义的对象,然后通过使用该对象来调用jQuery的方法和功能。这种做法有助于提高代码的可维护性和可复用性,因为代码的结构更加清晰,易于理解和管理。 在创建jQuery命名空间时,可以使用自定义的对象或命名空间作为一个全局变量,然后将jQuery的方法和功能添加到该对象。例如,可以使用如下方式创建一个名为`myApp`的命名空间: ``` var myApp = {}; ``` 然后,可以将jQuery的方法和功能添加到该命名空间,例如: ``` myApp.doSomething = function() { // 使用jQuery的方法 $("element").hide(); }; ``` 通过使用命名空间,可以更好地组织和管理jQuery代码。命名空间可以帮助防止全局变量的污染,并且可以更好地管理代码的作用域。此外,通过将相关的代码放在一个命名空间,可以更轻松地查找和修改代码,同时也方便了团队协作和代码的复用。 总结起来,jQuery命名空间是一种将所有jQuery相关代码组织在一起的方式,它可以提高代码的可维护性和可复用性,避免与其他代码库的冲突,并使代码更加结构化和可管理。 ### 回答3: jQuery命名空间是指在使用jQuery库时给函数、方法、变量等命名时使用的前缀。它的作用是避免不同的库或代码之间的命名冲突,保证代码的可维护性和可扩展性。 在jQuery,通过使用命名空间可以将一些特定的代码或功能集到一个名称下,避免与其他代码产生冲突。一般来说,我们会将自己编写的代码都放在一个自定义的命名空间下,如: ``` var myNamespace = { myMethod: function() { // 代码实现 }, myProperty: 'some value' }; ``` 在上述代码,myNamespace就是自定义的命名空间,而myMethod和myProperty则是属于该命名空间下的函数和变量。通过使用命名空间,我们可以确保这些函数和变量在全局范围内不会与其他代码冲突。 同时,使用命名空间还可以提高代码可读性和维护性。当我们在代码看到`myNamespace.myMethod()`时,就可以很清楚地知道这是属于自定义命名空间的方法。而不同的命名空间之间也可以相互调用,在需要时可以方便地扩展和修改。 总之,jQuery命名空间是一种在使用jQuery库时用来避免命名冲突、提高代码可维护性和可扩展性的机制。通过定义自己的命名空间,并将相关的函数和变量放在其,可以方便地组织和管理代码,确保代码的良好结构和可读性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值