`
liss
  • 浏览: 847706 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

javascript面向对象之二 命名空间

阅读更多

javascript中本没有命名空间的概念,但是要体现面向对象的思想,应当有命名空间,就像java中的package,.net中的namespace一样,作用主要为了防止类名冲突,相同的类名只要属于不同的命名空间,便不会冲突。

 

最简单创建命名空间的方法:

var java = {};
java.util = {};
//这样就创建成功了命名空间:java.util 
//我们可以在java.util下面加类(函数),属性,或对象 
java.util.HashMap = function() {
	this.ShowMessage = function() {
		alert("java.util.HashMap");
	}
}
var map = new java.util.HashMap();
alert(map.ShowMessage()); //显示结果:java.util.HashMap 

 

封装创建命名空间的方法:

//定义一个对象,js中用{}花括号定义对象,等同于 var JsObject = new Object();
var JsObject = {};

//在JsObject对象下定义一个函数namespace
JsObject.namespace = function() {
	/*
	 * 下面代码中arguments为函数传入的参数, 在function未明确定义参数时,
	 * function也可以传入参数,并用arguments来接收, arguments类似数组,
	 * 如果传入多个参数,将按顺序保存,取值法:arguments[0],arguments[1]....
	 */
	var a = arguments;
	var o = null;
	var d;
	var rt;
	for ( var i = 0; i < a.length; i++) {
		d = a[i].split('.'); // 将传入的参数用符号'.' 进行分割,并放入d数组中。
		rt = d[0];
		// 判断数组中的第一个值是否未定义,如果未定义,便定义为空对象{},并赋值给变量o
		eval('if (typeof ' + rt + ' == "undefined"){' + rt + ' = {};} o = ' + rt + ';');
		for ( var j = 1; j < d.length; j++) {
			/*
			 * 循环遍历数组d每个值作为key,加入到对象o中,如果key在o中存在,则取o中值,若 不存在,则赋值为空对象{}
			 */
			o[d[j]] = o[d[j]] || {};
			o = o[d[j]];
		}
	}
}

JsObject.namespace("org.myJs"); // 申明命名空间:org.myJs
//在命名空间org.myJs下定义类Student
org.myJs.Student = function() {
	// 定义类Student中的变量,并赋予初值,但此变量的访问权限是public
	this.studentNo = 's001';
	this.studentName = '小明';
	this.sex = '男';
}
var s = new org.myJs.Student(); // 创建Student类的对象
alert('学号:' + s.studentNo);
alert('姓名:' + s.studentName);
alert('性别:' + s.sex);

 

 

 

 

 

 

分享到:
评论
1 楼 hyl523 2013-05-03  
// 判断数组中的第一个值是否未定义,如果未定义,便定义为空对象{},并赋值给变量o 
        eval('if (typeof ' + rt + ' == "undefined"){' + rt + ' = {};} o = ' + rt + ';'); 
        for ( var j = 1; j < d.length; j++) { 
            /*
             * 循环遍历数组d每个值作为key,加入到对象o中,如果key在o中存在,则取o中值,若 不存在,则赋值为空对象{}
             */ 
            o[d[j]] = o[d[j]] || {}; 
            o = o[d[j]]; 
        } 
下面这些看得不大明白啊。。。。

相关推荐

    JavaScript 面向对象编程详细讲解文档

    JavaScript是一种动态类型的脚本语言,虽然它不像Java或C#那样拥有传统的类和实例机制,但它的面向对象编程能力仍然非常强大。JavaScript的核心在于对象、原型和隐式继承,这些都是理解其面向对象特性的重要概念。 ...

    JavaScript面向对象编程指南.pdf

    ### JavaScript面向对象编程指南 #### 一、面向对象编程(OOP)简介 面向对象编程(Object-Oriented Programming,简称OOP)是一种编程范式,它通过“对象”这一概念来设计软件。在OOP中,对象是数据和操作这些数据...

    JavaScript 面向对象之命名空间

    在JavaScript中,由于其动态类型和基于原型的面向对象特性,实现命名空间有多种方式,这里我们介绍一种基于函数的实现方法。 首先,我们需要创建一个全局的`RegisterNameSpace`函数,这个函数接受一个参数,即命名...

    javascript面向对象教程

    6. **模块和封装**:虽然JavaScript原生不支持模块系统,但可以通过立即执行函数表达式(IIFE)和命名空间等技术实现模块化和封装。 7. **鸭子类型**:JavaScript倾向于“鸭子测试”而非静态类型检查,如果对象的...

    Javascript 面向对象 命名空间

    javascript中本没有命名空间的概念,但是要体现面向对象的思想, 应当有命名空间,就像java中的package,.net中的namespace一样, 作用主要为了防止类名冲突,相同的类名只要属于不同的命名空间,便不会冲突。...

    JavaScript面向对象编程

    JavaScript面向对象编程是一种基于原型(Prototype)的编程范式,它是动态类型语言,允许开发者创建具有复杂特性的对象。在JavaScript中,面向对象主要通过构造函数、原型链和闭包来实现。以下是对这一主题的详细...

    javascript面向对象

    ### JavaScript面向对象编程详解 #### 一、现代JavaScript概述 随着技术的发展,JavaScript这门语言逐渐从最初的简单脚本语言成长为现在广泛应用于Web前端、后端甚至桌面应用的强大编程工具。现代JavaScript具备...

    JavaScript面向对象编程指南

    JavaScript是一种广泛应用于Web开发的动态编程语言,尤其在构建交互式和富媒体网站时不可或缺。...《JavaScript面向对象编程指南》这本书会是深入这一主题的好资源,建议仔细阅读并实践其中的示例。

    javascript面向对象技术基础

    本篇文章将深入探讨JavaScript面向对象的基础知识。 1. **面向对象的概念** 面向对象编程(Object-Oriented Programming, OOP)是一种编程范式,它基于“对象”概念,将数据和操作数据的方法封装在一起。在...

    javascript面向对象之Javascript 继承

    上几节讲了 JavaScript 面向对象之命名空间 、 javascript 面向对象的JavaScript类 、 JavaScript 面向对象的之私有成员和公开成员 与 Javascript 面向对象之重载,大家可以先看上面的再继续往下看。在JavaScript...

    包含javascript的基础语法,面向对象的实现和设计模式实现.zip

    javascript 命名空间面向对象1. JavaScript 表达能力2.接口3.简介4.继承5.AOPJquery[jQuery][9] [jQuery架构设计与实现][10] [jQuery选择器库][11] [zepto][12]1. jQuery 插件推荐2. jQuery 中闭包Javascript 设计...

    Javascript 面向对象之重载

    上几节讲了 JavaScript 面向对象之命名空间 、 javascript 面向对象的JavaScript类 与 JavaScript 面向对象的之私有成员和公开成员 ,大家可以先看上面的再继续往下看。假如 我这样定义: 代码如下: function ...

    面向对象javascript笔记

    面向对象的JavaScript编程是JavaScript开发中的重要概念,它允许我们以类和对象的方式来组织和处理数据。以下是对标题和描述中涉及的知识点的详细解释: 1. **引用**:在JavaScript中,对象是通过引用传递的,这...

    javascript的基础语法,面向对象的实现和设计模式实现

    6.javascript 命名空间 Oject-Oriented 1.JavaScript Expressive 2. Interfaces 3.Introduction 4. Inheritance 5.AOP Jquery [jQuery][9] [jQuery架构设计与实现][10] [jQuery选择器库][11] [zepto][12] 1....

    JavaScript 面向对象的之私有成员和公开成员

    上两节讲了 JavaScript 面向对象之命名空间 与 javascript 面向对象的JavaScript类,大家可以先看上面的再继续往下看。其实很简单,废话少说,看了下面的代码及注释相信你就会一目了然! 代码如下: //声明类,就是一...

    JavaScript03 面向对象编程.pdf_前端学习资料

    总的来说,JavaScript的面向对象编程涉及了类与原型的比较、继承机制、封装、多态、命名空间等核心概念。理解并熟练运用这些概念是成为专业前端开发者的关键步骤。通过学习和实践,开发者可以创建出高效、易于维护的...

Global site tag (gtag.js) - Google Analytics