工厂模式

工厂模式

1. UML 演示

在这里插入图片描述

  • 将new操作单独封装
  • 遇到new时,需要考虑

2. 代码演示

class Product {
  constructor(name) {
    this.name = name
  }

  init() {
    alert('init')
  }
  fn1() {
    alert('fn1')
  }
  fn2() {
    alert('fn2')
  }
}

class Creator {
  create(name) {
    return new Product(name)
  }
}

//测试
let creator = new Creator()
let p = creator.create('p1')
p.init()
p.fn1()

3. 场景

3.1 jQuery - $(‘div’)

  • $('div')new $(''div)有何区别
  • 前者是工厂模式
  • 书写麻烦,jQuery 的链式操作将成为噩梦
  • 一旦 jQuery 名称变化会有问题

3.2 React.createElement

var profile = <div>
<img src="avatar.png" className="profile"/>
<h3>{[
  user.firstName,
  user.lastName
  ].join(' ')
  }</h3>
var profile = React.createElement(
  'div',
  null,
  react.createElement('img', {
    src: 'avatar.png',
    className: 'profile'
  }),
  React.createElement('h3', null, [user.firstName, user.lastName].join(' '))
)

3.3 vue 异步组件

Vue.component('async-demo', function(resolve, reject) {
  setTimeout(function() {
    resolve({
      template: '<div>async</div>'
    })
  }, 1000)
})

4. 设计原则

  • 构造函数和创建者分离

  • 符合开放封闭原则

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值