JavaScript创建命名空间(namespace)的最简实现

 更新时间:2007年12月11日 18:57:54   投稿:mdxy-dxy  
JavaScript创建命名空间(namespace)通过自定义函数进行类型判断、数组遍历、函数执行等相关操作来实现命名空间的功能,需要的朋友可以参考一下

最近看Ext源代码,看到了其实现命名空间函数的实现方法:

Ext NameSpace实现代码: 
      

复制代码 代码如下:

  namespace : function(){ 
            var a=arguments, o=null, i, j, d, rt; 
            for (i=0; i<a.length; ++i) { 
                d=a[i].split("."); 
                rt = d[0]; 
                eval('if (typeof ' + rt + ' == "undefined"){' + rt + ' = {};} o = ' + rt + ';'); 
                for (j=1; j<d.length; ++j) { 
                    o[d[j]]=o[d[j]] || {}; 
                    o=o[d[j]]; 
                } 
            } 
        } 



鄙人喜好最简编程(这很多时候并不是一个好习惯,写的越简单程序一般越难理解),于是就想用更短的方式解决这个问题。
尝试了将近半个小时写下了下面的实现,基本该考虑的情况都考虑,至少不会覆盖页面已经存在的函数。

实现代码如下:
复制代码 代码如下:

function namespace(ns){ 
    if(typeof(ns)!="string")return; 
    ns=ns.split("."); 
    var o,ni; 
    for(var i=0,len=ns.length;i<len,ni=ns[i];i++){ 
       try{o=(o?(o[ni]=o[ni]||{}):(eval(ni+"="+ni+"||{}")))}catch(e){o=eval(ni+"={}")} 
    } 



你可以保存以下代码进行测试:

测试代码:

复制代码 代码如下:

<script type="text/javascript"> 
  <!-- 
    function namespace(ns){ 
        if(typeof(ns)!="string")return; 
        ns=ns.split("."); 
        var o,ni; 
        for(var i=0,len=ns.length;i<len,ni=ns[i];i++){ 
            try{o=(o?(o[ni]=o[ni]||{}):(eval(ni+"="+ni+"||{}")))}catch(e){o=eval(ni+"={}")} 
        } 
    } 
    function a(){return 5} 
    namespace("a.b"); 
    alert(a); 
    alert(a.b) 
    namespace("test.test.abc") 
    test.test.abc.func1=function(){ 
        alert('func1 run') 
    } 
    alert(test.test) 
    test.test.abc.func1(); 
  //--> 
</script>

相关文章

  • 解决layer弹出层msg的文字不显示的问题

    解决layer弹出层msg的文字不显示的问题

    今天小编就为大家分享一篇解决layer弹出层msg的文字不显示的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • 微信小程序使用setData修改数组中单个对象的方法分析

    微信小程序使用setData修改数组中单个对象的方法分析

    这篇文章主要介绍了微信小程序使用setData修改数组中单个对象的方法,结合具体实例形式分析了setData进行数组修改的相关操作技巧与注意事项,需要的朋友可以参考下
    2018-12-12
  • JS面试题---关于算法台阶的问题

    JS面试题---关于算法台阶的问题

    下面小编就为大家带来一篇JS面试题---关于算法台阶的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-07-07
  • element-ui 上传图片后标注坐标点

    element-ui 上传图片后标注坐标点

    有个组件库的名称叫做element-ui,基于Vue2.0开发,提供了丰富的PC端组件,本文通过实例代码给大家介绍element-ui 上传图片后标注坐标点的示例代码,感兴趣的朋友跟随小编一起看看吧
    2021-07-07
  • JavaScript中变量声明有var和没var的区别示例介绍

    JavaScript中变量声明有var和没var的区别示例介绍

    在函数内部,有var和没var声明的变量是不一样的。有var声明的是局部变量,没var的,声明的全局变量,所以可以借此向外暴露接口东东
    2014-09-09
  • javascript跨浏览器的属性判断方法

    javascript跨浏览器的属性判断方法

    这篇文章主要介绍了javascript跨浏览器的属性判断的方法,需要的朋友可以参考下
    2014-03-03
  • 微信小程序block的使用教程

    微信小程序block的使用教程

    这篇文章主要介绍了微信小程序block的使用 ,微信小程序最近非常火热,实现起来也很简单,只要block就可以实现,需要的朋友可以参考下
    2018-04-04
  • JsRender for object语法简介

    JsRender for object语法简介

    这篇文章主要介绍了JsRender for object语法,以实例形式讲述了for Object的用法,需要的朋友可以参考下
    2014-10-10
  • javascript针对不确定函数的执行方法

    javascript针对不确定函数的执行方法

    这篇文章主要介绍了javascript针对不确定函数的执行方法,实例分析了eval函数及符号属性两种执行方式,需要的朋友可以参考下
    2015-12-12
  • JavaScript数组实现扁平化四种方法详解

    JavaScript数组实现扁平化四种方法详解

    扁平化,顾名思义就是减少复杂性装饰,使其事物本身更简洁、简单,突出主题。数组扁平化,对着上面意思套也知道了,就是将一个复杂的嵌套多层的数组,一层一层的转化为层级较少或者只有一层的数组
    2022-10-10

最新评论