解开Ajax技术生命中的达芬奇密码

2016-01-29 11:23 6 1 收藏

解开Ajax技术生命中的达芬奇密码,解开Ajax技术生命中的达芬奇密码

【 tulaoshi.com - Javascript 】

 现在,Ajax技术发展势头迅猛,开发者已经建立了一个调用大量客户端javascript、不断增长的、复杂的系统。因此,在JavaScript上尝试OO技术便成为了管理复杂性的一种手段。在此过程中,多数开发者很快便认识到:JavaScript是一种原型化的(prototypical)语言,它缺少OO自身带来的多种便利。
  几乎每位在开发JavaScript时尝试应用面向对象技术的开发者,或多或少都会问自己一个问题:“如何调用父类(super class)的方法?”在Ajax技术还没有目前这样炙手可热之前,这种问题很少出现,因为大多数开发者仅在进行客户端form验证或者简单的DHTML/DOM操作时使用JavaScript。在那些简单的解决方案中,函数式编程(functional programming)是很有意义的,面向对象编程则处在次之重要的位置。
  现在,Ajax技术发展势头迅猛,开发者已经建立了一个调用大量客户端JavaScript、不断增长的、复杂的系统。因此,在JavaScript上尝试OO技术便成为了管理复杂性的一种手段。在此过程中,多数开发者很快便认识到:JavaScript是一种原型化的(prototypical)语言,它缺少OO自身带来的多种便利。
  OO设计的主旨和关于它的一些话题谈起来很大,但只着眼于Class的定义方式,我认为它是JavaScript开发者尝试解决问题的首选。因此,你可以在互联网上找到许多不同的问题解决案例,但在我看过它们后不免有些失望——这些案例都是在某个场合下适用,而不是放之四海而皆准的通法。而我对这个话题的兴趣来自于我的team在开发 ThinWire Ajax Framework 的影响。
  由于这个框架生成出对客户端代码的需求,才使我们“被迫”去实现可靠的、支持父类方法调用的OO模式。通过父类调用,你可以进一步依靠类的继承特性来核心化通用代码,从而更易于减少重复代码,去掉客户端代码的坏味道。
  下面罗列出了一些在我的研究过程中遇到的解决方式。最终,我没有从中找出一个可以接收的解决方案,于是我不得不实现一个自己的解决方案,你将在本文的结尾部分看到这个方案。
  然而父类调用在这里是最重要的OO机制,因此我需要一个相应的工作模式,也正是因为在我的观点中原型化方式是丑陋的,所以我更需要一种更加自然地使用JavaScript定义类的方法。
  More Solutions:
  好吧,让我们进入讨论。正如开发者所察觉的那样,在JS中实现基本的继承是很容易的事,事实上有一些众所周知的方法:
  丑陋的Solution:
  没有进行父类调用的简单继承:
// 提前写好的JavaScript Class定义和继承
// 当然,这种代码很丑陋,散发着代码的坏味道。
function BaseClass() {
    //BaseClass constructor code goes here 
}
BaseClass.prototype.getName = function() {
    return "BaseClass";
}
function SubClass() {
    //SubClass constructor code goes here 
}
//Inherit the methods of BaseClass
SubClass.prototype = new BaseClass();
//Override the parent’s getName method
SubClass.prototype.getName = function() {
    return "SubClass";
}
//Alerts "SubClass"
alert(new SubClass().getName());
 

  导致 IE内存泄露 的Solution:
  这种实现方式能够导致在IE中的内存泄漏,你应该尽量避免:
// 运行时的JavaScript Class 定义和继承
// 看上去很传统,但这些脚本会导致在Internet Explorer中的内存泄漏.
function BaseClass() {
    this.getName = function() {
        return "BaseClass";
    };    
    //BaseClass constructor code goes here  [next]
}
function SubClass() {
    //在对象实例建立时重载父类的getName方法 
    this.getName = function() {
        return "SubClass";
    }
    //SubClass constructor code goes here 
}
//Inherit the methods of BaseClass
SubClass.prototype = new BaseClass();
//Alerts "SubClass"
alert(new SubClass().getName());

来源:http://www.tulaoshi.com/n/20160129/1482275.html

延伸阅读
标签: 养生 健康
1、130下心跳 运动什么时候正适合­不专业不要紧,请记得每分钟心跳至少达到130下。当你热身完进入主运动时,摸摸自己的脉搏,每10秒有无超过21下,这样才算是做了有氧运动,燃脂效果最好! 2、10分钟静坐 每天10分钟的静坐,就能让你解除沉重压力,恢复活力。选一个安静的角落,试着让自己安静下来,只专注你的呼吸,慢...
标签: Web开发
Web开发领域的最新时髦术语其实质是“旧貌换新颜”。 Ajax(Asynchronous JavaScript and XML)是结合了Java技术、XML以及JavaScript等编程技术,可以让开发人员构建基于Java技术的Web应用,并打破了使用页面重载的惯例。 Ajax是使用客户端脚本与Web服务器交换数据的Web应用开发方法。这样,Web页面不用打断交互流程进行重新加裁,就可以动...
标签: Web开发
Ajax技术是目前在浏览器中通过JavaScript脚本可以使用的所有技术的集合。Ajax并没有创造出某种具体的新技术,它所使用的大多数技术都是在很多年以前就已经存在了,然而Ajax以一种崭新的方式来使用所有的这些技术,使得古老的B/S方式的Web开发焕发了新的活力,迎来了第二个春天。 具体来说,Ajax基于下列这些核心技术: XHTML:对应W...
标签: 心理健康
注意到那小男孩以前,他一直躺在病床上发呆。 大夫一再告诉他这只是一个良性肿瘤的切除手术,没有多大的危险,也不会影响他的将来。可是,大夫并不知道他在担忧什么。为了准备这次手术,他打了两个月的工,又向一位远房亲戚借了一笔钱,他不想让为了供他上大学已经受尽委屈的父亲再操心。 这时,病房里走进一个约五六岁的小男孩,那...
现实社会中,我们会看到各种各样的人,其中就有气质的不同。而有的人给人的感觉就是草根,而有的人给人的感觉就是高贵的。那么12生肖中哪些人天生有贵气?12生肖什么时候出生的人好?下面就一起来看看吧。 贵气不是每个人都有,比如我们常说的气宇轩昂、气场强大都是形容一个人具有贵气,下面我们一起来看看哪些生肖天生命中带贵气呢? ...

经验教程

972

收藏

24
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部