<!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>
相关推荐
在JavaScript编程中,命名空间和闭包是两个重要的概念,特别是在大型项目中,它们有助于保持代码的整洁和可维护性。下面将详细解释这两个概念以及它们在jQuery中的应用。 **命名空间**: 命名空间是为了避免全局...
练习使用js自定义命名空间,使用了到了js的单体对象及js的闭包知识。通过一个网页程序进行演示说明
传统的JavaScript命名空间通常是通过创建一个全局对象,然后将所有相关的函数和变量作为该对象的属性来实现的。例如: ```javascript var MyNamespace = { func1: function() {}, func2: function() {}, var1: '...
JavaScript 本身并不直接支持命名空间的概念,但可以通过对象和闭包来模拟实现。以下是一些实现命名空间的常见方法: 1. **对象嵌套**: 在给定的示例中,`com.anyjava` 是一个命名空间,它通过对象嵌套的方式创建...
#### 三、通过闭包和对象实现命名空间 闭包可以用来保护命名空间内的私有变量和方法,同时也可以通过返回的对象来暴露公共接口。 **示例代码**: ```javascript var namespace = namespace || {}; namespace....
- **模块化**:闭包可以帮助创建独立的命名空间,避免全局变量污染。 - **记忆化**:在函数式编程中,闭包可以用于缓存计算结果,提高重复计算的效率。 7. **注意事项** - 闭包可能导致意外的变量状态改变,因为...
1. **函数私有化**:通过闭包,我们可以创建私有变量和函数,这有助于避免全局命名空间的污染,提高代码的可维护性和封装性。 2. **模块模式**:使用闭包可以实现模块化编程,通过返回一个对象来暴露公共方法,同时...
JavaScript 中的命名空间这是一个小函数,它为您在 JavaScript 中声明和使用命名空间提供了一个很好的、简单的语法。 除了处理命名空间之外,它不会做任何事情:例如,它不会尝试加载其他脚本或模块。 它遵循我的...
以下是五种创建JavaScript命名空间的方法: 1. **通过函数(function)创建** 这种方法通常涉及定义一个函数,然后在函数内部声明变量和方法。例如: ```javascript var namespace = namespace || {}; namespace....
这样,`fn`的执行逻辑被安全地封装起来,外部无法直接调用,避免了对全局命名空间的污染: ```javascript function fn(){ console.log("fn") } Person.prototype={ constructor:Person, s1:function(){ fn()...
5. **作用域与污染全局命名空间**: 使用匿名函数和函数直接量,特别是通过立即调用的方式,可以避免在全局作用域中创建变量,从而减少潜在的命名冲突和全局变量污染。 6. **框架中的应用**: 许多JavaScript框架...
在JavaScript编程中,命名空间是一个重要的概念,它的主要目的是解决全局变量可能引起的命名冲突问题。本文将详细介绍JavaScript中创建命名空间的5种常见方法。 首先,我们来看一下全局变量引发的命名冲突问题。在...
总结起来,虽然JavaScript语言本身不支持命名空间,但通过函数作用域、立即执行函数表达式、对象字面量以及闭包等技术,开发者能够有效地组织和隔离代码,模拟出类似其他编程语言中的命名空间的功能。这对于维护大型...
namespace.js是一个为了在JavaScript中提供命名空间功能而设计的库,它允许开发者通过定义命名空间来组织和封装代码。 命名空间对象的定义通常包括了对象本身以及用于创建对象的方法。例如,namespace.js库中的`...