近期总结的一些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;
// }
相关推荐
xiaotao1312 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉2 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro3 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常3 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆3 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶3 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐3 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅4 小时前
Vue如何集成封装Axios
前端·javascript·vue.js
康一夏4 小时前
Next.js 13变化有多大?
前端·react·nextjs
糖炒栗子03264 小时前
前端项目标准环境搭建与启动
前端