`
didasoft
  • 浏览: 164807 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Atlas与面向对象的Javascript

阅读更多

英文链接: http://atlas.asp.net/docs/atlas/doc/javascript/default.aspx

按我的理解,面向对象基本的特性无非六个字:封装、继承和多态。研究了Atlas的文档之后,发现它的Javascript脚本库把这几个特性都实现了。Ok, Let go......

先看看封装

Atlas提供了命名空间Namespace的功能来隔离命名冲突,而且在类中可以定义私有变量,达到的封装的目的。可惜的是类的方法好像只能是公共的。

以下是示例代码(所有的示例代码来自于原文链接)

Type.registerNamespace("Demo");

Demo.Person 
= function(firstName, lastName, emailAddress) {
    
var _firstName = firstName;
    
var _lastName = lastName;
    
var _emailAddress = emailAddress;
    
    
this.getFirstName = function() {
        
return _firstName;
    }

    
    
this.getLastName = function() {
        
return _lastName;
    }

    
    
this.getEmailAddress = function() {
        
return _emailAddress;
    }

    
    
this.setEmailAddress = function(emailAddress) {
        _emailAddress 
= emailAddress;
    }

    
    
this.getName = function() {
        
return _firstName + ' ' + _lastName;
    }


    
this.dispose = function() {
        alert('bye ' 
+ this.getName());
    }

}

Demo.Person.registerClass('Demo.Person', 
null, Sys.IDisposable);

定义了以上的Demo.Person类之后,就可以在页面中的Javascript代码中按OO的方法使用了。

        var testPerson = new Demo.Person('John', 'Smith', 'john.smith@example.com');
        alert(testPerson.getFirstName() 
+ " " + testPerson.getLastName() );

然后来看看继承

Demo.Person.prototype.sendMail = function() {
    
var emailAddress = this.getEmailAddress();

    
if (emailAddress.indexOf('@') < 0{
        emailAddress 
= emailAddress + '@example.com';
    }

    alert('Sending mail to ' 
+ emailAddress + ' ');
}


Demo.Person.prototype.toString 
= function() {
    
return this.getName() + ' (' + this.getEmailAddress() + ')';
}


Demo.Employee 
= function(firstName, lastName, emailAddress, team, title) {
    Demo.Employee.initializeBase(
this, [firstName, lastName, emailAddress]);
    
    
var _team = team;
    
var _title = title;
    
    
this.getTeam = function() {
        
return _team;
    }

    
this.setTeam = function(team) {
        _team 
= team;
    }

    
    
this.getTitle = function() {
        
return _title;
    }

    
this.setTitle = function(title) {
        _title 
= title;
    }

}

Demo.Employee.registerClass('Demo.Employee', Demo.Person);

Demo.Employee.prototype.toString 
= function() {
    
return Demo.Employee.callBaseMethod(this, 'toString') + '\r\n' + this.getTitle() + '\r\n' + this.getTeam();
}

简单地说,就是用prototype定义虚函数。使用registerCalss定义基类,构造函数调用initializeBase

最后,我们来看看多态

其实上面的代码toString函数已经实现了继承的多态。我们再来看看接口实现的多态:

Type.registerNamespace("Demo.Animals");

Demo.Animals.IPet 
= function() {
    
this.returnFriendlyName = Function.abstractMethod;
}

Demo.Animals.IPet.registerInterface('Demo.Animals.IPet');


Demo.Animals.Animal 
= function(name) {
    
var _name = name;
    
    
this.returnName = function() {
        
return _name;
    }

}

Demo.Animals.Animal.registerAbstractClass('Demo.Animals.Animal');

Demo.Animals.Animal.prototype.toStringCustom 
= function() {
    
return this.returnName();
}

Demo.Animals.Animal.prototype.speak 
= Function.abstractMethod;


Demo.Animals.Pet 
= function(name, friendlyName) {
    Demo.Animals.Pet.initializeBase(
this, [name]);
    
    
var _friendlyName = friendlyName;
    
this.returnFriendlyName = function() {
        
return _friendlyName;
    }

}

Demo.Animals.Pet.registerAbstractClass('Demo.Animals.Pet', Demo.Animals.Animal, Demo.Animals.IPet);


Demo.Animals.Cat 
= function(friendlyName) {
    Demo.Animals.Cat.initializeBase(
this, ['Cat', friendlyName]);
}

Demo.Animals.Cat.registerClass('Demo.Animals.Cat', Demo.Animals.Pet);

Demo.Animals.Cat.prototype.speak 
= function() {
    alert('meow');
}


Demo.Animals.Cat.prototype.toStringCustom 
= function() {
    
return 'Pet ' + Demo.Animals.Cat.callBaseMethod(this, 'toStringCustom');
}


Demo.Animals.Felix 
= function() {
    Demo.Animals.Felix.initializeBase(
this, ['Felix']);
}

Demo.Animals.Felix.registerClass('Demo.Animals.Felix', Demo.Animals.Cat);

Demo.Animals.Felix.prototype.toStringCustom 
= function() {
    
return Demo.Animals.Felix.callBaseMethod(this, 'toStringCustom') + '  its Felix!';
}



Demo.Animals.Dog 
= function(friendlyName) {
    Demo.Animals.Dog.initializeBase(
this, ['Dog', friendlyName]);
}

Demo.Animals.Dog.registerClass('Demo.Animals.Dog', Demo.Animals.Pet);

Demo.Animals.Dog.prototype.speak 
= function() {
    alert('woof');
}



Demo.Animals.Tiger 
= function() {
    Demo.Animals.Tiger.initializeBase(
this, ['Tiger']);
}

Demo.Animals.Tiger.registerClass('Demo.Animals.Tiger', Demo.Animals.Animal);

Demo.Animals.Tiger.prototype.speak 
= function() {
    alert('grrr');
}

首先,用registerInterface定义一个接口

然后,在registerClass的时候,第三个参数指定类实现了哪个接口

Atlas还支持抽象类的定义(registerAbstractClass)

确实算是比较完备了。

看到这里,还是比较兴奋。Javascript终于也可以以OOP的方式来编写了,其扩展的潜力不可低估啊。






 

分享到:
评论

相关推荐

    atlas:用于alt的1#Typescript面向对象框架

    《Atlas:为Alt打造的TypeScript面向对象框架》 在IT行业中,框架是开发者们构建应用程序的基础,它们提供了预设的结构和模式,使得代码编写更加高效和规范。本文将深入探讨“Atlas”这一专为Alt设计的TypeScript...

    征服RIA:基于JavaScript的Web客户端开发卷二

    JavaScript高级篇:揭示JavaScript的运行机理和高级应用,如面向对象编程、函数式编程和元编程。Ajax篇:Ajax是上帝赐予JavaScript的礼物。凭借着Ajax,JavaScript拥有了异步调度服务端业务逻辑的能力。本篇除介绍...

    征服RIA:基于JavaScript的Web客户端开发卷三

    JavaScript高级篇:揭示JavaScript的运行机理和高级应用,如面向对象编程、函数式编程和元编程。Ajax篇:Ajax是上帝赐予JavaScript的礼物。凭借着Ajax,JavaScript拥有了异步调度服务端业务逻辑的能力。本篇除介绍...

    JavaScript连接数据库实例

    此外,ORM(对象关系映射)工具如Sequelize、TypeORM或Mongoose,可以帮助开发者用更面向对象的方式操作数据库,降低了数据库操作的复杂性。 2. 安装依赖 要开始JavaScript数据库连接,首先需要安装相应的数据库...

    atlas做的聊天室

    VB.NET是.NET Framework的一部分,是一种面向对象的编程语言,其语法简洁,易于上手,非常适合快速开发。 【知识点详解】: 1. **ATLAS框架**:ATLAS(现在被称为Microsoft AJAX Library)是微软对AJAX技术的扩展...

    Ajax与Atlas设计高质量的Ajax应用

    1. **Ajax的基本工作原理**:Ajax通过JavaScript创建XMLHttpRequest对象,然后使用这个对象与服务器进行通信。当用户触发某个事件(如点击按钮)时,JavaScript函数被调用,发送一个HTTP请求到服务器。服务器处理...

    面向对象的Ajax

    面向对象的Ajax是一种编程实践,它利用面向对象的特性,如封装、继承和多态,来组织和管理AJAX(Asynchronous JavaScript and XML)应用程序。这种方法可以提高代码的可读性、可维护性和复用性,尤其在处理复杂的...

    Project-Atlas:完善的地形图解决方案

    开发者需要熟悉如何组织代码,以及如何利用Python的面向对象编程特性来设计可维护的软件结构。 2. **地理数据处理**:项目涉及处理地理数据,这可能包括栅格数据(如数字高程模型,DEM)和矢量数据(如边界、道路、...

    Cocos Creator笔记

    2. 面向对象编程:JS是基于原型的面向对象语言,掌握类、对象、继承和多态的概念,有助于构建复杂的项目结构。 3. 异步编程:理解Promise、async/await用于处理异步操作,能有效管理代码的执行顺序,避免回调地狱。 ...

    cpp-nEXT最快高效的Web浏览器

    3. **面向对象**:C++的面向对象特性使得代码结构清晰,易于维护,适合开发大型复杂项目如Web浏览器。 4. **库支持**:C++拥有丰富的标准库和第三方库,如Qt或Poco,这些库为开发Web浏览器提供了强大的功能支持,如...

    Ajax基础教程(扫描版)

    5.7.1 通过prototype属性建立面向对象的javascript 142 5.7.2 私有属性和使用javascript的信息隐藏 146 5.7.3 javascript中基于类的继承 148 5.7.4 汇合 149 5.8 小结 152 第6章 使用jsunit测试javascript代码 ...

    ajax初学必读

    1. **异步通信**:Ajax的核心是XMLHttpRequest对象,它允许JavaScript在不重新加载整个页面的情况下与服务器进行交互。异步意味着用户可以在等待响应时继续使用其他功能,提高了交互性。 2. **JavaScript处理**:...

    ASP.NET AJAX深入浅出

    文章详细列举了ASP.NET AJAX的核心组件,如Microsoft AJAX Library,它包含了JavaScript基础扩展、浏览器兼容层、面向对象类型系统、异步通信层和客户端基础类库等。这些组件共同构建了一个强大且易用的开发平台,...

    cocos2d-x蛇梯棋(cocos creator)

    开发者需要理解JavaScript的基本语法、面向对象编程、事件处理以及如何与Cocos Creator的组件系统交互。 3. **UI设计**:蛇梯棋的游戏界面由多个UI元素构成,如棋盘、骰子、角色等。Cocos Creator提供了丰富的UI...

    texture_packer.zip

    TypeScript是JavaScript的一个超集,它引入了静态类型系统和面向对象特性,提高了代码的可维护性和可读性。在Egret项目中使用TypeScript,开发者可以利用其强大的类型检查和代码提示功能,编写出更健壮的游戏代码。...

    WroxProfessional Ajax

    Ajax的核心原理在于利用JavaScript实现页面与服务器之间的异步通信,通过XMLHttpRequest对象发送HTTP请求,并接收响应数据。书中详细介绍了如何创建和使用这个对象,以及如何处理请求和响应的生命周期。 在.NET框架...

    ASP.NET 2.0 入门与提高 陈锐老师课程系列三

    至于C#语言,它是ASP.NET的主要编程语言,提供了面向对象、类型安全和垃圾回收等特性。在用户界面编程中,C#的事件处理机制尤其关键,它允许开发者轻松地编写响应用户操作的代码。 总的来说,陈锐老师的这门课程将...

    tindev-omnistack8

    同时,Node.js与MongoDB通过Mongoose库进行数据交互,Mongoose提供了面向对象的数据模型,简化了数据库操作。 MongoDB作为NoSQL数据库,以JSON格式存储数据,非常适合处理结构多变或半结构化的数据。Mongo Atlas...

Global site tag (gtag.js) - Google Analytics