`
风雨百年6462
  • 浏览: 2082 次
  • 来自: 成都
最近访客 更多访客>>
社区版块
存档分类
最新评论

js命名空间和闭包

阅读更多

 

 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
 <head>
  <title> New Document </title>
  <meta name="Generator" content="EditPlus">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <script src="jquery-1.9.1.js"></script>
 </head>

 <body>
  
 </body>
</html>
<script>
//一、命名空间
var Namespace=new Object();
Namespace.register = function(path){     
    var arr = path.split(".");     
    var ns = "";     
    for(var i=0;i<arr.length;i++){     
        if(i>0) ns += ".";     
        ns += arr[i]; 
		//eval执行动态js代码
        eval("if(typeof(" + ns + ") == 'undefined') " + ns + " = new Object();");     
    }     
}    
Namespace.register("com.xcx.util"); 
Namespace.register("com.xcx.entity");
com.xcx.util.getName=function(){
 alert("xcx");
}
com.xcx.util.getName();

com.xcx.entity.person = function(){  
    //变量作用域为函数内部,外部无法访问  
    var name = "default";
    return {  
       getName : function(){  
           return name;  
       },  
       setName : function(newName){  
           name = newName;  
       },
	   chifan:function(){
	     alert("用手吃饭");
	   }
    }
};
var person=com.xcx.entity.person();
/*alert(person.name);//直接访问,结果为undefined  
alert(person.getName());  
person.setName("pingping");  
alert(person.getName());
person.chifan();*/
//二、jQuery闭包
(function ($) {
    $.problemWo = function () { };
	/*$.extend(dest,arg1,arg2,arg3……);
	  1、合并第二道第n个参数
	  2、如以下例子将会合并成{b:5,myclick:function(){alert("c");}},
	     特别地:agr1和arg2有相同的属性,后面的将会覆盖前面的属性
	  3、如果dest=true,则arg参数的子对象将会覆盖,dest=false子对象将会被舍去
	*/
    $.extend($.problemWo,
             { b: 5 },
             { myclick: function () { alert("c") } 
			 
			 }
            );
})(jQuery);

var a=(function(){
  var name="default";
  return {getName:function(){alert("pingping");}};
})();

//a.getName();
//alert($.problemWo.b);
//$.problemWo.myclick();


//声明一个对象$.problemWo,添加一个a的实例属性和myclick的实例方法。

(function ($) {
    $.problemWo = function () {
        this.a = "abc"
    };
    $.extend($.problemWo.prototype, 
                {myclick: function () { alert(this.a); }}
                );
})(jQuery);

var obj = new $.problemWo()
obj.myclick();

//判断全局变量是否定义,没有就抛出异常
if(typeof jQuery==="undefined")throw "没有引入jQuery.js文件";
if(typeof jquery==="undefined")throw "没有引入test.js文件";
</script>

 

分享到:
评论

相关推荐

    jQuery命名空间与闭包用法示例

    在JavaScript编程中,命名空间和闭包是两个重要的概念,特别是在大型项目中,它们有助于保持代码的整洁和可维护性。下面将详细解释这两个概念以及它们在jQuery中的应用。 **命名空间**: 命名空间是为了避免全局...

    使用js自定义命名空间

    练习使用js自定义命名空间,使用了到了js的单体对象及js的闭包知识。通过一个网页程序进行演示说明

    JS命名空间的一种改进版本

    传统的JavaScript命名空间通常是通过创建一个全局对象,然后将所有相关的函数和变量作为该对象的属性来实现的。例如: ```javascript var MyNamespace = { func1: function() {}, func2: function() {}, var1: '...

    javascript简单实现命名空间效果.docx

    JavaScript 本身并不直接支持命名空间的概念,但可以通过对象和闭包来模拟实现。以下是一些实现命名空间的常见方法: 1. **对象嵌套**: 在给定的示例中,`com.anyjava` 是一个命名空间,它通过对象嵌套的方式创建...

    javascript创建命名空间的5种写法_.docx

    #### 三、通过闭包和对象实现命名空间 闭包可以用来保护命名空间内的私有变量和方法,同时也可以通过返回的对象来暴露公共接口。 **示例代码**: ```javascript var namespace = namespace || {}; namespace....

    js闭包的介绍

    - **模块化**:闭包可以帮助创建独立的命名空间,避免全局变量污染。 - **记忆化**:在函数式编程中,闭包可以用于缓存计算结果,提高重复计算的效率。 7. **注意事项** - 闭包可能导致意外的变量状态改变,因为...

    闭包javascript.pdf

    1. **函数私有化**:通过闭包,我们可以创建私有变量和函数,这有助于避免全局命名空间的污染,提高代码的可维护性和封装性。 2. **模块模式**:使用闭包可以实现模块化编程,通过返回一个对象来暴露公共方法,同时...

    namespace.js:一个在 JavaScript 中创建命名空间的简单函数

    JavaScript 中的命名空间这是一个小函数,它为您在 JavaScript 中声明和使用命名空间提供了一个很好的、简单的语法。 除了处理命名空间之外,它不会做任何事情:例如,它不会尝试加载其他脚本或模块。 它遵循我的...

    javascript创建命名空间的5种写法__1.docx

    以下是五种创建JavaScript命名空间的方法: 1. **通过函数(function)创建** 这种方法通常涉及定义一个函数,然后在函数内部声明变量和方法。例如: ```javascript var namespace = namespace || {}; namespace....

    JS实现闭包中的沙箱模式示例

    这样,`fn`的执行逻辑被安全地封装起来,外部无法直接调用,避免了对全局命名空间的污染: ```javascript function fn(){ console.log("fn") } Person.prototype={ constructor:Person, s1:function(){ fn()...

    (转载)JavaScript中匿名函数,函数直接量和闭包.docx

    5. **作用域与污染全局命名空间**: 使用匿名函数和函数直接量,特别是通过立即调用的方式,可以避免在全局作用域中创建变量,从而减少潜在的命名冲突和全局变量污染。 6. **框架中的应用**: 许多JavaScript框架...

    JavaScript创建命名空间的5种写法

    在JavaScript编程中,命名空间是一个重要的概念,它的主要目的是解决全局变量可能引起的命名冲突问题。本文将详细介绍JavaScript中创建命名空间的5种常见方法。 首先,我们来看一下全局变量引发的命名冲突问题。在...

    JavaScript 命名空间 使用介绍

    总结起来,虽然JavaScript语言本身不支持命名空间,但通过函数作用域、立即执行函数表达式、对象字面量以及闭包等技术,开发者能够有效地组织和隔离代码,模拟出类似其他编程语言中的命名空间的功能。这对于维护大型...

    namespace.js Javascript的命名空间库

    namespace.js是一个为了在JavaScript中提供命名空间功能而设计的库,它允许开发者通过定义命名空间来组织和封装代码。 命名空间对象的定义通常包括了对象本身以及用于创建对象的方法。例如,namespace.js库中的`...

Global site tag (gtag.js) - Google Analytics