近期总结的一些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;
// }
相关推荐
文火冰糖的硅基工坊2 分钟前
[光学原理与应用-480]:《国产检测设备对比表》
前端·人工智能·系统架构·制造·半导体·产业链
excel10 分钟前
Qiankun 子应用生命周期及使用场景解析
前端
weixin_4462608514 分钟前
Django - 让开发变得简单高效的Web框架
前端·数据库·django
蓝莓味的口香糖16 分钟前
【JS】什么是单例模式
开发语言·javascript·单例模式
ObjectX前端实验室1 小时前
【react18原理探究实践】异步可中断 & 时间分片
前端·react.js
SoaringHeart1 小时前
Flutter进阶:自定义一个 json 转 model 工具
前端·flutter·dart
努力打怪升级1 小时前
Rocky Linux 8 远程管理配置指南(宿主机 VNC + KVM 虚拟机 VNC)
前端·chrome
brzhang2 小时前
AI Agent 干不好活,不是它笨,告诉你一个残忍的现实,是你给他的工具太难用了
前端·后端·架构
brzhang2 小时前
一文说明白为什么现在 AI Agent 都把重点放在上下文工程(context engineering)上?
前端·后端·架构
reembarkation2 小时前
自定义分页控件,只显示当前页码的前后N页
开发语言·前端·javascript