[Typescript] Intersections types

interface Order {
  id: string;
  amount: number;
  currency: string;
}

interface Stripe {
  card: string;
  cvc: string;
}

interface PayPal {
  email: string;
}

type CheckoutCard = Order & Stripe;
type CheckoutPayPal = Order & PayPal;

const order: Order = {
  id: 'xj28s',
  amount: 100,
  currency: 'USD'
};

const orderCard: CheckoutCard = {
  ...order,
  card: '1000 2000 3000 4000',
  cvc: '123'
};

const orderPayPal: CheckoutPayPal = {
  ...order,
  email: 'abc@def.com'
};

 

Object.assign: in typescript, it can understand the intersection:

const assigned = Object.assign({}, order, orderCard); // assign<T, U, V>(target: T, source1: U, source2: V): T & U & V;

posted @ 2020-10-06 15:18  Zhentiw  阅读(72)  评论(0编辑  收藏  举报