引用:http://ourjs.com/detail/538d8d024929582e6200000c
 
在JavaScript中全局变量经常会引起命名冲突,甚至有时侯重写变量也不是按照你想像中的顺序来的,可以看看下面的例子:
 
  1. var sayHello = function() {
  2. return 'Hello var';
  3. };
  4.  
  5. function sayHello(name) {
  6. return 'Hello function';
  7. };
  8.  
  9. sayHello();
 
最终的输出为
 
  1. > "Hello var"
 
为什么会这样,根据 StackOverFlow 的解释,实际上JavaScript的是按如下顺序解析的。

  1. function sayHello(name) {
  2. return 'Hello function';
  3. };
  4.  
  5. var sayHello = function() {
  6. return 'Hello var';
  7. };
  8.  
  9. sayHello();
 
不带var的function声明被提前解析了,因此现代的JS写法建议你始终使用前置var声明所有变量;
 
避免全局变量名冲突的最好办法还是创建命名空间,下面是在JS中合建命名空间的几种常用方法。
 
 
通过函数(function)创建
 
这是一种比较常见的写法,通过声明一个function实现,函数里设置初始变量,公共方法写入prototype,如:
 
  1. 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
 
  1. /*
    Object
    */
    var NameSpace = window.NameSpace || {};
    NameSpace.Hello = {
        name: 'world'
      , sayHello: function(_name) {
        return 'Hello ' + (_name || this.name);
      }
    };
 
调用
 
  1. NameSpace.Hello.sayHello('JS');
    > Hello JS;
 
这种写法比较紧凑,缺点是所有变量都必须声明为公有(public)的,导致所有对这些变量的引用都需要加this指示作用域,写法也略有冗余。
 

通过闭包(Closure)和Object实现

 
在闭包中声明好所有变量和方法,并通过一个JSON Object返回公有接口:
 
  1. 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对象。
 
  1. 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
 
  1. var NameSpace = window.NameSpace || {};
    NameSpace.Hello = new function() {
      var self = this;
      var name = 'world';
      self.sayHello = function(_name) {
        return 'Hello ' + (_name || name);
      };
    };

调用

  1. NameSpace.Hello.sayHello();

JavaScript中创建命名空间的更多相关文章

  1. 在JavaScript中创建命名空间的几种写法

    在JavaScript中全局变量经常会引起命名冲突,甚至有时侯重写变量也不是按照你想像中的顺序来的,可以看看下面的例子: var sayHello = function() { return 'Hel ...

  2. JavaScript中创建类,赋值给ajax中的data参数

    缘由:因为要给根据是否选中checkbox来动态增加ajax中data的属性(ajax的data属性格式的几种方法,参考http://www.jb51.net/article/46676.htm) d ...

  3. JavaScript中创建字典对象(dictionary)实例

    这篇文章主要介绍了JavaScript中创建字典对象(dictionary)实例,本文直接给出了实现的源码,并给出了使用示例,需要的朋友可以参考下 对于JavaScript来说,其自身的Array对象 ...

  4. 简单使用JSON,JavaScript中创建 JSON 对象(一)

    JSON:JavaScript 对象表示法(JavaScript Object Notation). JSON 是存储和交换文本信息的语法.类似 XML. JSON 比 XML 更小.更快,更易解析. ...

  5. JavaScript中创建数组的方式!

    JavaScript中创建数组的方式! 利用数组字面量 // 1 直接量 console.log(Array.prototype); var arr = [1, 2, 4, 87432]; // 注意 ...

  6. js中创建命名空间的几种写法

    在JavaScript中全局变量经常会引起命名冲突,甚至有时侯重写变量也不是按照你想像中的顺序来的,可以看看下面的例子: var sayHello = function() { return 'Hel ...

  7. 在js中创建命名空间的几种写法

    在JavaScript中全局变量经常会引起命名冲突,甚至有时侯重写变量也不是按照你想像中的顺序来的,可以看看下面的例子:   var sayHello = function() { return 'H ...

  8. Javascript 中创建自定义对象的方法(设计模式)

    Javascript 中创建对象,可以有很多种方法. Object构造函数/对象字面量: 抛开设计模式不谈,使用最基本的方法,就是先调用Object构造函数创建一个对象,然后给对象添加属性. var ...

  9. JavaScript 中的命名空间

    全局变量应该由有系统范围相关性的对象们保留,并且它们的命名应该避免含糊并尽量减少命名冲突的风险.在实践中,这意味着你应该避免创建全局对象,除非它们是绝对必须的. 所以你对此是怎么做的?传统方法告诉我们 ...

随机推荐

  1. TimePicker控件、帧动画、补间动画

    1.TimePicker控件 最近感觉每个开发平台的控件基本都差不多,在Android中控件的事件和.net控件直接写事件有一定的区别,net事件可以直接界面进行事件的绑定哈.不过在Silverlig ...

  2. Android面试必备

    好吧,说实话是自己面试被问到的和自己整理的别人的一些问题,很多问题的回答可能根据水平不同层次和深度不同,如果经常忘的话可能是还没明白原理,学习就是对对抗遗忘,现在开始复习吧: 每个面试的问题都极大的贴 ...

  3. zookeeper_02:zookeeper基础

    ZooKeeper基础概述 ZooKeeper维护一个小型的数据节点,这些节点被称为znode,采用类似于文件系统的层级树状结构进行管理. 针对一个znode,没有数据常常表达了重要的信息.比如,在主 ...

  4. 贝叶斯网络基础(Probabilistic Graphical Models)

    本篇博客是Daphne Koller课程Probabilistic Graphical Models(PGM)的学习笔记. 概率图模型是一类用图形模式表达基于概率相关关系的模型的总称.概率图模型共分为 ...

  5. 原生JS研究:学习jquery源码,收集整理常用JS函数

    原生JS研究:学习jquery源码,收集整理常用JS函数: 1. JS获取原生class(getElementsByClass) 转自:http://blog.csdn.net/kongjiea/ar ...

  6. 关于jQuery中的ajax的方法介绍

           jQuery提供一系列Ajax函数方便我们调用Ajax, 其中最核心也是最复杂的是jQuery.ajax(),所有的其他Ajax函数都是它的一个简化调用.当我们想要完全控制Ajax时可以 ...

  7. Python简明教程---学习笔记

    字符双引号括起,数字不括: 分隔符为逗号(,),不能为空格 变量定义时即赋值 采用utf-8编码:#-*-coding:utf-8-*-或者#coding:utf-8 字符串定义:单/双引号括起 %符 ...

  8. Elevator

    问题陈述: 杭州电子科技大学 HANGZHOU DIANZI UNIVERSITY Online Judge Problem - 1008 问题分析: 简单题. 代码详解: #include < ...

  9. 一步一步学习SignalR进行实时通信_6_案例

    原文:一步一步学习SignalR进行实时通信_6_案例 一步一步学习SignalR进行实时通信\_6_案例1 一步一步学习SignalR进行实时通信_6_案例1 前言 类的定义 各块功能 后台 上线 ...

  10. why constrained regression and Regularized regression equivalent

    problem 1: $\min_{\beta} ~f_\alpha(\beta):=\frac{1}{2}\Vert y-X\beta\Vert^2 +\alpha\Vert \beta\Vert$ ...