TypeScript系列教程九《类型转换》-- 索引访问类型,保驾护航金三银四

25 阅读2分钟

TCP协议

  • TCP 和 UDP 的区别?
  • TCP 三次握手的过程?
  • 为什么是三次而不是两次、四次?
  • 三次握手过程中可以携带数据么?
  • 说说 TCP 四次挥手的过程
  • 为什么是四次挥手而不是三次?
  • 半连接队列和 SYN Flood 攻击的关系
  • 如何应对 SYN Flood 攻击?
  • 介绍一下 TCP 报文头部的字段
  • TCP 快速打开的原理(TFO)
  • 说说TCP报文中时间戳的作用?
  • TCP 的超时重传时间是如何计算的?
  • TCP 的流量控制
  • TCP 的拥塞控制
  • 说说 Nagle 算法和延迟确认?
  • 如何理解 TCP 的 keep-alive?

浏览器篇

  • 浏览器缓存?
  • 说一说浏览器的本地存储?各自优劣如何?
  • 说一说从输入URL到页面呈现发生了什么?
  • 谈谈你对重绘和回流的理解
  • XSS攻击
  • CSRF攻击
  • HTTPS为什么让数据传输更安全?
  • 实现事件的防抖和节流?
  • 实现图片懒加载?

开源分享:docs.qq.com/doc/DSmRnRG…

type Age = Person["age"];

//type Age = number

类型的索引访问类型,我们可以使用联合类型,keyof 或者 其他type:

type I1 = Person["age" | "name"];

//type I1 = string | number

type I2 = Person[keyof Person];

//type I2 = string | number | boolean

type AliveOrName = "alive" | "name";

type I3 = Person[AliveOrName];

//type I3 = string | boolean

如果index属性不存在的话,TS会报错

type I1 = Person["alve"];

//Property 'alve' does not exist on type 'Person'.

使用任意类型进行索引的另一个示例是使用number获取数组元素的类型。我们可以将其与typeof相结合,方便地捕获数组文本的元素类型:

const MyArray = [

{ name: "Alice", age: 15 },

{ name: "Bob", age: 23 },

{ name: "Eve", age: 38 },

];

type Person = typeof MyArray[number];

// type Person = {

// name: string;

// age: number;

// }

type Age = typeof MyArray[number]["age"];

// type Age = number

// Or

type Age2 = Person["age"];

// type Age2 = number

最后

本人分享一下这次字节跳动、美团、头条等大厂的面试真题涉及到的知识点,以及我个人的学习方法、学习路线等,当然也整理了一些学习文档资料出来是给大家的。知识点涉及比较全面,包括但不限于前端基础,HTML,CSS,JavaScript,Vue,ES6,HTTP,浏览器,算法等等

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

前端视频资料: