工具类型

Partial

Partial的用处如以下举例:当接口中的属性在有些情况下是可选参数的,有些情况下是必选参数。Partial拿出部分属性的属性,作用把泛型的类型(<>尖括号的接口类型)属性设置属性为可选参数。

js 复制代码
// 定义两个接口满足以上要求
interface Pt1{
    name:string;
    age:number;
}
interface Pt2{
    name?:string;
    age?:number;
}
js 复制代码
//采用Partial,只需要定义一个接口
interface People {
  name:string;
  age:number;
}
// 泛型放入接口的类型
let peopleObj:Partial<People>={
  name:"jessica",
  age:418
}
let people:Partial<People>={
  name:"hyo",
}
let people2:Partial<People>={
  name:Gloria,
  age:undefined
}

type Partial<T> = { [P in keyof T]?: T[P] | undefined; }这段代码的含义为T这个泛型在使用时就是传入的接口的类型,将来这个类型依然是一个对象。P in keyof T就是遍历接口中的属性,P相当于一个临时变量用于保存遍历出的接口属性nameageT[P]表示取出接口中属性的属性值就是stringnumber。即这段代码最终呈现结果为一个对象:

js 复制代码
// 问号表示可选属性
{
    name?:string|undefined,
    age?:number|undefined
}

Required

Required的用处如以下举例:当接口中的属性有可选参数,但有些情况下需要这个可选参数是必选参数。Required的作用是把泛型的类型(<>尖括号的接口类型)属性设置属性为必选参数。

js 复制代码
interface People {
  name:string;
  age:number;
  height?:number
}
// 泛型放入接口的类型
let peopleObj:Required<People>={
    // 编译报错
  name:"jessica",
  age:418
}

type Required<T> = { [P in keyof T]-?: T[P]; }这段代码的含义为T这个泛型在使用时就是传入的接口的类型,将来这个类型依然是一个对象。P in keyof T就是遍历接口中的属性,P相当于一个临时变量用于保存遍历出的接口属性nameageheightT[P]表示取出接口中属性的属性值就是stringnumbernumber-?表示抵消去掉问号,有问号就减去问号,没有就不需要减去。即这段代码最终呈现结果为一个对象:

js 复制代码
// 问号表示可选属性
{
    name:string|undefined,
    age:number|undefined,
    height:number|undefined,
}
相关推荐
GISer_Jing6 小时前
前端营销技术实战:数据+AI实战指南
前端·javascript·人工智能
GIS之路7 小时前
使用命令行工具 ogr2ogr 将 CSV 转换为 Shp 数据(二)
前端
嘉琪0017 小时前
Vue3+JS 高级前端面试题
开发语言·前端·javascript
vipbic8 小时前
用 Turborepo 打造 Strapi 插件开发的极速全栈体验
前端·javascript
天涯学馆8 小时前
为什么 JavaScript 可以单线程却能处理异步?
前端·javascript
Henry_Lau6178 小时前
主流IDE常用快捷键对照
前端·css·ide
陶甜也8 小时前
使用Blender进行现代建筑3D建模:前端开发者的跨界探索
前端·3d·blender
我命由我123458 小时前
VSCode - Prettier 配置格式化的单行长度
开发语言·前端·ide·vscode·前端框架·编辑器·学习方法
HashTang8 小时前
【AI 编程实战】第 4 篇:一次完美 vs 五轮对话 - UnoCSS 配置的正确姿势
前端·uni-app·ai编程
JIngJaneIL9 小时前
基于java + vue校园快递物流管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js