导航


HTML

CSS

JavaScript

浏览器 & 网络

版本管理

框架

构建工具

TypeScript

性能优化

软实力

算法

UI、组件库

Node

冷门技能

Untitled

interface 求交集

interface Colorful {
  color: string
}
interface Circle {
  radius: number
}
type ColorfulCircle = Colorful & Circle // 接口也能求交集

const cc: ColorfulCircle = {
  color: 'blue',
  radius: 23
}

type 模拟继承

type Person = {
  name: string
  age: number
}
type User = Person & {
  id: number
  email: string
}
const u: User = {
  id: 1,
  name: 'Lance',
  age: 18,
  email: '[email protected]'
}

属性冲突求交集

type Person = {
  id: string
  name: string
  age: number
}
type User = Person & {
  id: number
  email: string
}
const u: User = {
  id: 1, // never 属性冲突,求的是交集
  name: 'Lance',
  age: 18,
  email: '[email protected]'
}

interface 扩展

interface Person {
  id: string
  name: string
  age: number
}
interface User extends Person {
  id: number
  email: string
}

Untitled