JS中的工厂模式和构造函数模式

工厂方法创建对象

function createPerson(name , age , gender){
    var obj = new Object();
    //向对象中添加属性
    obj.name = name;
    obj.age = age;
    obj.gender = gender;
    obj.say = function(){
        alert(this.name);
    }
    return obj;
}
var obj2 = createPerson("猪八戒" , 18 , "男");
var obj3 = createPerson("孙悟空" , 18 , "男");
obj2.say();//猪八戒
obj3.say();//孙悟空

使用工厂方法创建的对象,使用的构造函数都是Object
所以创建的对象都是Object这个类型,导致无法区分出多种不同类型的对象

构造函数就是一个普通的函数,创建方式和普通函数没有区别,不同的是构造函数习惯上首字母大写
构造函数和普通函数的区别就是调用方式的不同
普通函数是直接调用,而构造函数需要使用new关键字来调用

构造函数的执行流程:

  1. 立刻创建一个新的对象
  2. 将新建的对象设置为函数中this,在构造函数中可以使用this来引用新建的对象
  3. 逐行执行函数中的代码
  4. 将新建的对象作为返回值返回
function Person(name , age , gender){
    this.name = name;
    this.age = age;
    this.gender = gender;
    this.say = function(){
        alert(this.name);
    }
}
var per = new Person("孙悟空" ,18 , "男");
var per2 = new Person("猪八戒" ,18 , "男");
per.say();//孙悟空
per2.say();//猪八戒

function Animal(name , say){
    this.name = name;
    this.say = say;
    this.saym = function(){
        alert(this.say+this.say);
    }
}
var cat = new Animal("猫" , "喵喵");
cat.saym();//喵喵喵喵

使用同一个构造函数创建的对象,我们称为一类对象,也将一个构造函数称为一个类。
我们将通过一个构造函数创建的对象,称为是该类的实例
使用instanceof可以检查一个对象是否是一个构造函数的实例
语法:

对象 instanceof 构造函数

所有对象都是Object的后代,因此任何对象与Object作instanceof检查时都会返回true

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值