search

Home  >  Q&A  >  body text

javascript - 关于js生成命名空间的一段代码

    function ns(namespace) {
        var _ns = namespace.split(".");
        var cur = window[_ns[0]];
        if(cur === undefined) cur = window[_ns[0]] = {};
        var len = _ns.length;
        for(var i = 1; i < len; i++)
            cur = cur[_ns[i]] = cur[_ns[i]] || {};
        return cur;
    }

这段代码中 cur = cur[_ns[i]] = cur[_ns[i]] || {}; 是什么作用?如何执行?不是很理解cur[_ns[i]] = cur[_ns[i]] 和= cur[_ns[i]] || {};这两部分如何执行。
ps:为何要return cur?跟踪的道德结果只是一个没有内容的object

迷茫迷茫2775 days ago599

reply all(1)I'll reply

  • 迷茫

    迷茫2017-04-10 12:45:23

     function ns(namespace) {//假设传进一个包名:willerce.module.music
            var _ns = namespace.split(".");//将包使用.分割为一个数组
            var cur = window[_ns[0]];//window[_ns[0]]在这里就是 window.willerce ,获取 window.willerce 的值
            if(cur === undefined) cur = window[_ns[0]] = {};//如果window.willerce 不存在,赋值一个空对象
            var len = _ns.length;//得到包的长度,就是数组有多长
            for(var i = 1; i < len; i++)//循环赋值
                cur = cur[_ns[i]] = cur[_ns[i]] || {};//如果这个对象为undefined,就创建一个空对象
            //上面这个循环,大概就是判断 willerce.module 是否存在,不存在,赋值为空对象 {},然后将自己cur赋值为willerce.module
            //接着再判断willerce.module.music,同理,不存在就初始化。将 cur 赋值为 cur,这时 cur 就是  willerce.module.music 了
    
            //最后返回cur
    
              
    
            return cur;
        }

    这里的命名空间,其实就是一个对象。例如 willerce.module.music 这3段都是对象

    我们在给 music 赋值的时候,必须保证 willerce , willerce.module 都是一个对象(包含空对象),而不是 undefined。如果是 undefined,就要赋值为 {}

    所以这段代码的过程就是,判断对象是否初始化了,如果没,就始化为空对象。
    看懂这段代码,主要就是注意 cur 的变化。还有 undefined || {} 的意思是:如果第一个为undefined,就取第二个。

    reply
    0
  • Cancelreply