为了账号安全,请及时绑定邮箱和手机立即绑定

【十月打卡】第67天 前端常用的7种设计模式(3)

标签:
设计模式

类之间的关系

  • 实现(类对接口的实现,因为接口比较虚,所以用虚线空心箭头)
  • 泛化 (子类对父类的继承,父类是具体存在的,所以用实线空心箭头)
  • 引用(下面会细讲,引用关系的箭头都是实心箭头)

实现

  • 类对接口的实现【虚线 + 空心箭头】

代码演示:

interface PersonType {
  name: string;
  age: number;
  speak(val: string): void;
}

class Person implements PersonType {
  name: string;
  age: number;
  constructor(name: string, age: number) {
    this.name = name;
    this.age = age;
  }
  speak(val: string) {
    console.log(val);
  }
}

UML类图:
图片描述

泛化

  • 子类对父类的继承【实线 + 空心箭头】

代码演示:

class Person {
  name: string;
  age: number;
  constructor(name: string, age: number) {
    this.name = name;
    this.age = age;
  }
  speak(val: string) {
    console.log(val);
  }
}

class Teacher extends Person {
  constructor(name: string, age: number){
    super(name, age)
  }
  teach(){
    console.log('讲课')
  }
}

class Student extends Person {
  constructor(name: string, age: number){
    super(name, age)
  }
  study(){
    console.log('学习')
  }
}

UML类图:
图片描述

引用关系的细化

注:视频中老师用的是关联关系,加入了自己的一些思考,觉得引用关系这个词更加方便理解,也更加方便细分

  • 关联:互相独立,引用性比较强,一般作为属性来引入(比如职工和工卡的关系)
  • 依赖:互相独立,引用性比较弱,一般作为函数参数或者返回值(比如司机和车的关系)
  • 聚合:整体引用部分,部分可以脱离整体 (比如车和轮胎)
  • 组合:整体引用部分,部分不可以脱离整体(比如脸和嘴)

关联

  • 【实线 + 实心箭头】

代码演示:

class Employee {
  constructor(public name: string, public card: Card) {}
  work(){}
}

class Card {
  constructor(public id: number) {}
}

UML类图:
图片描述

依赖

  • 【虚线 + 实心箭头】

代码演示:

class Driver {
  constructor(public name: string) {}
  drive(car: Car){}
}

class Car {
  constructor(public type: string) {}
}

UML类图:
图片描述

聚合

  • 【空心菱形 + 实线 + 实心箭头】

代码演示:

class Car {
  constructor(public engine: Engine) {}
}

class Engine {
  constructor() {}
}

UML类图:
图片描述

组合

  • 【实心菱形 + 实线 + 实心箭头】

代码演示:

class Face {
  constructor(public mouth: Mouth) {}
}

class Mouth {
  constructor() {}
}

UML类图:
图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消