js面向对象

JS面向对象的几种写法

JS 中,面向对象有几种写法。归纳下,大概有下面这几种:工厂模式,构造函数模式,原型模式,构造函数与原型模式的混合使用,原型链继承,借用构造函数继承。

一、工厂模式

闭包使用的原理与之很相似,最后返回的

function person (name,age,jpb){

    var o={};//定义o这个对象

    o.name=name;

    o.age=age;

    o.job=job;

    o.sayName=function(){

        console.log(this.name);

    }

    return o;

}


    var demo=person('tj',22,'fe');

    console.log(demo);

二、构造函数模式

构造函数本身也是函数,只不过是一个创建对象的函数

function Person(name,age){   //构造函数以大写字母开头,普通函数以小写                  字母开头
    this.name=name;

    this.age=age;

    this.sayName=function(){

        console.log(this.name);

    };
}

var demo2=new Person('tj2',23);

console.log(tj2);

使用构造函数有一些注意点:必须使用new操作符,调用构造函数会经历以下四步:

1、创建一个新的对象

2、将构造函数的作用域给了新对象(this指向新对象),其中this 是全局变量,window.age 获取的结果是一样的。

3、对新对象添加属性

4、返回新对象

三、原型模式

每个函数都有一个prototype属性,这个属性是一直指针,指向一个对象,这个对象的用途是包含可以由特定类型的实例共享的属性和方法。

使用原型对象的好处是可以让所有对象实例共享他所包含的属性和方法。不必在构造函数中定义对象实例的信息,而是可以将这些信息直接添加到原型对象中。

function Person(){};

Person.prototype.name ='tj3';

Person.prototype.age=24;

Person.prototype.sayName= function(){

    alert(this.name)

}

var demo3= new Person();
console.log(demo3);



//更简单的原型办法

function Person(){};

Person.prototype={

    name:'tj4',

    age:25,

    sayName:function(){

        alert(this.name);

    }

};

var demo4=new Person();

console.log(demo4);

四、组合使用构造函数和原型模式

构造函数模式用于定义实例属性,而原型模式定义方法和共享的属性。这种混合模式还支持向构造函数传递参数。

function Person(name,age,job){

    this.name=name;

    this.age=age;

    this.job=job;

    this.sayName=function(){

        alert(this.name);

    }

}

Person.prototype ={

    sayJob:function(){

        console.log(this.job);

    }

}

五、原型链继承

原型链继承的主要思想是利用原型让一个引用类型继承另一个引用类型的属性和方法。

注意点:通过原型链继承是不能使用对象字面量创建原型方法,这样会重写原型链!

function SuperType(){

    this.color=['red','blue'];

}

function SubType(){}

Subtype.prototype=new SuperType();//继承了SuperType

var instance1=new SubType();

console.log(instance1);

六、借用构造函数继承

其实就是用call和apply实现继承

function wanda(){

    this.money=[1,2,3];

}

function sicong(){

    wanda.call(this);

}

var sc = new sicong();

sc.money.push(666);

console.log(sc);

七、组合继承

将原型链和借用构造函数的技术组合起来一起用,好处是既能实现函数的复用,又能保证每个实例有自己的属性。

function SuperType(name) {

    this.name = name;

    this.color = ['red', 'blue'];

};

SuperType.prototype.sayName = function() {

    console.log(this.name);

};

function SubType(name, age) {

    SuperType.call(this, name);//继承属性

    this.age = age;

};

SubType.prototype = new SuperType();//继承方法

var instance1 = new SubType('tj', 22);

instance1.sayName();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值