ts之 Mixin混入(ts对象的混入、类的混入)

ts之 Mixin混入

对象的混入

interface Name {
  name: string;
}
interface Age {
  age: number;
}
interface Sex {
  sex: number;
}
let aa: Name = { name: "ppp" };
let bb: Age = { age: 10 };
let cc: Sex = { sex: 1 };
let obj = Object.assign(aa, bb, cc); // let obj: Name & Age & Sex

类的混入

// 类的混入 mixin
class AA {
  type: boolean;
  changeType() {
    this.type = !this.type;
  }
  constructor(type: boolean) {
    this.type = type;
  }
}
class BB {
  name: string;
  public changeName(name: string): string {
    return this.name = name;
  }
  constructor(name: string) {
    this.name = name;
  }
}
// @ts-ignore // @ts-ignore

class CC implements AA, BB {
  type: boolean = false;
  name: string = "ppp";
  // @ts-ignore
  changeType: () => void;
  // @ts-ignore
  changeName: (name: string) => string; // 属性“changeType”没有初始化表达式,且未在构造函数中明确赋值
}

mixins(CC, [AA, BB]);
function mixins(curCls: any, itemCls: any[]) {
  itemCls.forEach((item) => {
    // console.log("item", item); // item [class AA] item [class BB]
    Object.getOwnPropertyNames(item.prototype).forEach((name) => {
      curCls.prototype[name] = item.prototype[name];
    });
  });
}
let ccc = new CC();
console.log("ccc", ccc.name); // ccc ppp
console.log("ccc", ccc.type); // ccc flase
ccc.changeType();
console.log("ccc", ccc.type); // ccc true
ccc.changeName("小小");
console.log("ccc", ccc.name); // ccc 小小
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值