资讯专栏INFORMATION COLUMN

古老的面向对象编程

sutaking / 475人阅读

摘要:面向对象编程一段完整的创建类的示例如何创建一个类,包含有静态属性方法,公有私有属性方法静态私有变量静态私有方法安全模式,防止未使用操作符私有变量方法公有属性,方法静态公有属性静态共有方法使用关闭包定义静态私有变量与方法,所有实例创建过程中都

面向对象编程

一段完整的创建类的示例

// 如何创建一个类,包含有:静态属性方法,公有私有属性方法?
var Book = (function(){
    // 静态私有变量 
    var bookNum = 0; 
    
    // 静态私有方法
    function checkName(name){} 
    
    var _book = function(id, newName, newPrice) { 
        // 安全模式,防止未使用new操作符
        if(this instanceof _book){ 
            // 私有变量 方法 
            var name, price; 
            function checkID(){
            } 
            
            // 公有属性,方法 
            this.id = id; 
            this.getName = function(){ return name; }; 
            this.getPrice = function(){ return price; }; 
            this.setName = function(name){ name = name; };
            this.setPrice = function(price){ price = price; }; 
            console.log(++bookNum); 
            this.setName(newName); 
            this.setPrice(newPrice);  
        } 
        else{ 
            return new _book(id, name, price); 
        } 
    };
    
    _book.prototype = { 
        // 静态公有属性 
        isJSBook: false,
        // 静态共有方法 
        displayName: function(){ 
            console.log(this.getName());
        } 
    };
    
    return _book;
}());
使用关闭包定义静态私有变量与方法,所有实例创建过程中都能访问到

创建实例时,打印出累加之后的bookNum

当替换Book(即_book)的原型之后,之前创建的实例指向的原型并不会改变,之后在之后创建Book实例时运用新的原型

观察b3、b4的原型

当在原来的原型上变更之后,通过该原型创建的实例都能应用变更之后的原型

这里定义重复了,原型上的getPrice方法将会被实例自身拥有的getPrice方法掩盖住

继承

方式一:类式继承: 通过将子类的原型指定为父类的实例

function SuperClass(){ 
    this.superValue = true;
}
SuperClass.prototype.getSuperValue = function(){ 
    return this.superValue;
};
function SubClass(){
    this.subValue = true;
}
SubClass.prototype = new SuperClass();
SubClass.prototype.getSubValue = function(){ return this.subValue;};

缺点:
1、如果父类中存在引用类型属性,则会被所有子类共用,一个子类修改之后将会影响到所有子类
2、无法在实例化时为父类传递初始化参数

方式二: 构造函数继承: 在子类构造函数中通过call或者apply调用父类的构造函数,实现继承父类定义的属性方法

function SuperClass(id){
    this.books = ["js", "css", "html"];
    this.id = id;
}
SuperClass.prototype.showBooks = function(){
    console.log(this.books.join());
};
function SubClass(id){
    SuperClass.call(this, id);
}

缺点:
1、子类没有继承父类的原型
2、每个实例化出来的子类对象都会多带带拥有一份父类上定义的属性方法,无法复用父类的属性或者方法

方式三: 组合继承: 方式一与方式二的组合模式

function SuperClass(name){
    this.name = name;
    this.books = ["js", "css","html"];
}
SuperClass.prototype.getName = function(){
    console.log(this.name);
};
function SubClass(name, time){
    SuperClass.call(this, name);
    this.time = time;
}
SubClass.prototype = new SuperClass();
SubClass.prototype.getTime = function(){ console.log(this.time);}

缺点:
1、父类构造函数执行了两遍
2、子类实例化出来的对象原型中重复了一次父类构造函数中的属性方法

方式四: 原型式继承: 使用过渡函数作为构造函数,传入的对象作为过渡函数的原型

function inheritObject(o){
    function F(){}
    F.prototype = o;
    return new F();
}
缺点:
跟方式一有相同的缺点

方式五: 寄生式继承: 在方式四的基础上进行二次封

function createBook(obj){
    var o = inheritObject(obj);
    o.getName = function(){
        console.log(this.name); 
    };
    
    return o;
}

方式六: 寄生组合式继承: 寄生式继承跟够构造函数继承的组合

function inheritPrototype(SubClass, SuperClass){
    var p = inheritObject(SuperClass.prototype);
    p.constructor = SubClass;
    SubClass.prototype = p;
}
function SuperClass(name){
    this.name = name;
    this.books = ["js", "css","html"];
}
SuperClass.prototype.getName = function(){
    console.log(this.name);
};
function SubClass(name, time){
    SuperClass.call(this, name);
    this.time = time;
}
inheritPrototype(SubClass, SuperClass);
SubClass.prototype.getTime = function(){ console.log(this.time);
}

子类添加原型方法只能在现有原型上一个添加

整个过程:先定义子类及父类与父类原型,然后子类原型引用父类的原型对象,然后子类在添加自己的原型方法,最后调用父类构造函数

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/96321.html

相关文章

  • 假如时光倒流,我会这么学习Java

    摘要:看起来没有集合框架,线程,等那么耀眼,但它可是很多框架的基础啊回复反射查看相关文章,先把基础学会,后面的得用到它。 回头看看, 我进入Java 领域已经快15个年头了, 虽然学的也一般, 但是分享下我的心得,估计也能帮大家少走点弯路。[入门]我在2001年之前是C/C++阵营, 有C和面向对象的基础, 后来转到Java ,发现没有指针的Java真是好简单, 另外Java 的类库好用的让...

    bladefury 评论0 收藏0
  • polarphp:一个新 PHP 语言运行时环境

    摘要:项目介绍是一个全新的语言的运行时环境,基于目前最新的进行打造,支持最新的语言规范,同时提供了自己的运行时标准库。同样也在的基础上进行打造,实现了一个除开发之外的一个全新的运行环境。发布核心虚拟机的镜像。整合运行时框架。 showImg(https://segmentfault.com/img/bVbnQXK); polarphp 项目介绍 polarphp是一个全新的PHP语言的运行时...

    宋华 评论0 收藏0
  • 关于分布式计算一些概念

    摘要:关于三者的一些概括总结离线分析框架,适合离线的复杂的大数据处理内存计算框架,适合在线离线快速的大数据处理流式计算框架,适合在线的实时的大数据处理我是一个以架构师为年之内目标的小小白。 整理自《架构解密从分布式到微服务》第七章——聊聊分布式计算.做了相应补充和修改。 [TOC] 前言 不管是网络、内存、还是存储的分布式,它们最终目的都是为了实现计算的分布式:数据在各个计算机节点上流动,同...

    Ververica 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<