工厂模式与构造函数模式的区别

目录

一、工厂模式

二、构造函数模式

一、工厂模式

1. 工厂模式其实就是普通函数

2. 可以解决创建多个类似对象的问题,

3. 没有解决对象标识问题(即新创建的对象是什么类型)

// 工厂模式
function createPerson(name, age) {
    let o = new Object()
    o.name = name
    o.age = age
    o.sayName = () => {
    console.log(name)
  }
    return o
}

let person1 = createPerson('jack', 18)
console.log(person1)
person1.sayName()

 二、构造函数模式

与工厂模式(普通函数)的区别:

1.  没有显式地创建对象

2. 属性和方法直接赋值给了 this

3. 没有 return

// 构造函数模式
function Person(name, age) {
    this.name = name
    this.age = age
    this.sayName = () => {
        console.log(this.name)
  }
}

let person2 = new Person('tim', 20)
console.log(2, person2)
person2.sayName()

调用构造函数执行的操作(new执行的操作):

1. 在内存中创建一个新对象(new Object)

2. 新对象内部的 原型对象[[Prototype]] 被赋值为构造函数(function Person(){})的 原型对象,即新对象的 [[Prototype]]: Person.prototype

3. 构造函数内部的this被赋值为创建的新对象(this指向新对象)

4. 执行构造函数内部的代码(给新对象添加属性、方法)

5. 构造函数返回该对象

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值