近期总结的一些TypeScript小tip

const vs readonly

const 用于修饰变量,readonly 用于变量的属性

ts 复制代码
const x: boolean;

const x: {
    readonly a: boolean;
} = {
    a: true;
};

对于数组,const 只能保证地址不改动,ReadonlyArray<Number>则可以直接禁用 push/pop

never vs unknown vs null vs undefined

  1. never 代表永远不会发生的类型,一般是被自动分配的,当然也可以自己给变量做类型注释
ts 复制代码
function f1() {
  while (true) {}
}

function f2() {
  throw new Error('error');
}

f1f2都是永远返回不了的,称它们的返回值类型为是 never

  1. unknown 不知道是啥类型,但是肯定不是已知的类型,这是它和 any 最大的不同
ts 复制代码
let vAny: any = 10; // ok
let vUnknown: unknown = 10; // ok

let s1: string = vAny; // ok
let s2: string = vUnknown; // Invalid; we can't assign vUnknown to any other type (without an explicit assertion)
  1. undefined 是未定义,null 是空

enum vs const enum

常量枚举经过编译器编译就是一个数字(0),单纯的 enum 会保留对象(Color.Red),所以常量枚举性能更好

btw,默认 enum 转 number 是 0,1,2...

但是如果指定其中的一个值,后面的会跟着列出来

ts 复制代码
enum Colors {
  Red,
  Blue = 5,
  Yellow,
}
console.log(Colors.Red); // 0
console.log(Colors.Blue); // 5
console.log(Colors.Yellow); // 6

enum 支持反向映射

ts 复制代码
console.log(Colors.Red); // 0
console.log(Colors[0]); // Red

type vs interface

  1. type 可作为基本类型的别名
  2. type 可声明 union type Pet = Dog | Cat
  3. type 可声明元组类型(tuple) type PetList = [Dog, Pet]
  4. interface 能够声明合并
ts 复制代码
interface A {
  a: string;
}

interface A {
  b: number;
}

// A 为 {
//   a: string;
//   b: number;
// }
相关推荐
kyriewen17 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒17 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马18 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮18 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦18 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer18 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队18 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY18 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_19 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏19 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端