JavaScript面向对象

 

           JavaScript面向对象

 

面向对象的编程思想三大要素:

l       封装

l       继承

l       多态

JavaScript如何实现OOP

l       封装(Wrap)
JavaScript的对象封装,主要依靠function来实现。以下是一个简单的示例:

//*********************************************

// 定义Pet(宠物)对象

//*********************************************

function Pet() {

        //名称

        this.name = null;

        //颜色

        this.color = null;

        //获取名称

        this.getName = function() {

                return this.name;

        };

        //设置名称

        this.setName = function(newName) {

                this.name = newName;

        };

        //获取颜色

        this.getColor = function() {

                return this.color;

        };

        //设置颜色

        this.setColor = function(newColor) {

                this.color = newColor;

        };

        //定义一个需要实现的方法
        this.getFood = null;

        //获取宠物的描述信息

        this.toString = function() {

            return "The pet is " + this.name +",it's "

+this.color+",and it likes "+this.getFood()+".";
        };

}

l       继承(inheritance)
JavaScript的继承的实现主要依靠prototype(原型)来实现,下面为Pet类编写一个子类。

//*********************************************

// 定义Cat(猫)对象

//*********************************************

function Cat() {

        //实现Pet中定义的getFood方法

        this.getFood = function() {

                return "fish";

        };

}

//声明Cat的原型,即Cat的父类

Cat.prototype = new Pet;

多层次继承

//*********************************************

// 定义PersianCat(波斯猫)对象

//*********************************************

function PersianCat() {

}

//声明PersianCat的原型,即PersianCat的父类

PersianCat.prototype = new Cat;

l       重载(override)与多态(Polymorphism)

//重载Pet的toString方法

PersianCat.prototype.toString = function() {

        return "It's just a persian cat.";

};

 

转载于:https://www.cnblogs.com/kelebing/archive/2007/02/25/656250.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值