zoukankan      html  css  js  c++  java
  • 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
    可拍砖,欢迎拍砖!!!

  • 相关阅读:
    Andorid自定义attr的各种坑
    git 使用那些事儿
    Gradle task
    他们要消失了吗?探访人工智能浪潮下的鉴黄师
    测试环境docker化—容器集群编排实践
    测试环境docker化(一)—基于ndp部署模式的docker基础镜像制作
    后台服务项目的白盒测试之旅
    利用反向代理测应用的流量
    CCF 201312-5 I’m stuck! (暴力,BFS)
    CodeForces 709C Letters Cyclic Shift (水题)
  • 原文地址:https://www.cnblogs.com/broadview/p/1452363.html
Copyright © 2011-2022 走看看