JavaScript命名空间

发布于:2023-03-12 ⋅ 阅读:(81) ⋅ 点赞:(0)

什么是命名空间

命名空间(英语:Namespace)表示标识符(identifier)的可见范围。一个标识符可在多个命名空间中定义,它在不同命名空间中的含义是互不相干的。这样,在一个新的命名空间中可定义任何标识符,它们不会与任何已有的标识符发生冲突,因为已有的定义都处于其它命名空间中。(维基百科

命名空间的作用

当一个工程很大时,既有自身的代码,又有引用的外部库,当自身库和外部库中的对象重名时,没有命名空间将无法区分他们。

通用命名空间函数

JavaScript语言的与语法中,没有内置命名空间,但这种特征非常容易实现。添加到命名空间的属性可能已经存在,所以再添加属性或者创建命名空间之间,我们应该先检查命名空间是否存在。

var FN = FN || {};

如果定义FN.fn1.fn2,则:

var FN = FN || {};
var FN.fn1 = FN.fn1 || {};
var FN.fn1.fn2 = FN.fn1.fn2 || {};

可以看出每创建一个命名空间或者添加属性,都需要对对象或属性做附加检查,产生大量重复代码,这违背了DRY原则,也是产生命名空间函数的原因。我们希望通过以下命名空间函数调用产生以上效果:

FN.namespace("FN.fn1.fn2")

于是我们可以做以下实现:

    var FN = FN || {};
        FN.namespace = function(ns_string){
            var parts = ns_string.split("."),
            parent = FN,
            i;
            if(parts[0] === "FN"){
                left = parts.slice(1);
            }   
            for(i = 0 ;i < left.length; i += 1){            
                if(typeof parent[left[i]] === "undefined"{
                    parent[left[i]] = {};
                }
                parent = parent[left[i]] ;
            }
        }
     x = FN.namespace("FN.fn1.fn2");