JavaScript的对象观

 JavaScript的对象观


    众所周知,目前的JavaScript实现了ECMA262规范,是基于对象的。未来的JavaScript2.0具说是面向对象同时向后兼容亦可使用基于对象的手法,但在还未看到正式运行版前就不讨论了。
    基于对象。什么是基于对象呢?关于这个问题,初学者通常会与面向对象相对混淆。那到底什么是基于对象呢?要认定(纯粹个人看法)基于对象不等于面向对象; 基于对象的层次是高于面向对象的;基于对象是使用已经存在的对象或扩展已经存在的对象,而面向对象是设计或抽象出一个新的对象来,同时该对象具有继承、多 态、封装等特点。从另一个角度也可以认为基于对象是站在面向对象的肩膀上的。
    既然基于对象是站在面向对象的肩膀上的,那么基于对象语言自然拥有面向对象语言的特征,如JavaScript(本文围绕它来说,其他还有 ActionScript等)。那JavaScript是如何完成面向对象的呢?呵呵,这就是刚才为什么说那么多废话的原因了。本文的宗旨就是将阐述如何 在JavaScript 中使用面向对象。
    在《征服RIA——基于JavaScript的Web客户端开发》一书的第二部分《第二部分 JavaScript高级篇》简单阐述了JavaScript的对象特性。没错!正由于这些特性才造就了如今的JavaScript(忘记在那里见过这样 一种说法——JavaScript的设计者似乎都没发现JavaScript有这么多特性)。
    对象的创建、使用、继承等方式在这里就不啰嗦了,大家可以参考《征服RIA——基于JavaScript的Web客户端开发》的高级篇,当然了也欢迎拍砖呀。(本人经常上的blog——http://hi.baidu.com/nathena/)
    在面向对象编程的世界里往往离不开设计模式。自然现在我们谈到了面向对象,自然也引入了设计模式。哈哈,看到这里你是否觉得有种上当得感觉呢?对了说了好多好多,只是想说我要介绍JavaScript中的设计模式。恩,不废话。现在简单的介绍几种
    singletion(单例)
    可查看http://hi.baidu.com/nathena/blog/item/714948dd65b25e325882dd0d.html
var Singletion = {
constructor:function()
{
//保证实例的唯一性
//注意不能使用this
return Singletion;
},

basePay:4500,
allowance:200,
duty:2000,
other:3000,
affixation:1000
}

var a = Singletion;
var c = new (Singletion.constructor)();
alert(a===c)
    适配器(Adapter)
    可查看http://hi.baidu.com/nathena/blog/item/12b9882c7887a3eb8a1399af.html
funtion Stack()
    {
        //适配JS数组接口
        var d = [];
        //实际需要为仅提供peek、pop、push、search、isEmpty
        this.peek =function()
        {
            return d[0];
        }

        this.pop = function()
        {
            return d.pop();
        }

        this.search=function( o)
        {
            for(var i=0;i<d.length;i++)
            {
                if( d[i] == o )
                    return i;
            }
        }
        this.isEmpty = function()
        {
            return d.length==0?true:false;
        }
    }
    composite组合模式
var Win = function()
{
    
}

var Wall = function()
{
}

var Door = function()
{
}
var Room = function()
{
    this.win = new Win();
    this.Wall = new Wall();
    this.Door = new Door();
}
And so on ……………..
更多可以参看
http://hi.baidu.com/nathena/blog/category/web%C7%B0%B6%CB%BC%BC%CA%F5
可拍砖,欢迎拍砖!!!

posted @ 2009-05-08 08:54  博文视点(北京)官方博客  阅读(198)  评论(0编辑  收藏  举报