TypeScript的never类型的妙用

never类型介绍

在 TypeScript 中,"never" 是一个表示永远不会发生的值类型。

使用场景

"never" 类型通常用于以下几种情况:

1、函数返回类型:当一个函数永远不会返回任何值(比如抛出异常或者无限循环),可以将其返回类型标注为 "never"。

TypeScript 复制代码
function throwError(message: string): never {
    throw new Error(message);
}

2、死循环:如果一个函数包含无限循环,可以使用 "never" 类型来标记它的返回类型。

TypeScript 复制代码
function infiniteLoop(): never {
    while (true) {
    }
}

3、类型保护:在类型检查中,"never" 类型可以用于细化其他类型。例如,当使用类型保护时,可以使用 "never" 排除某些可能性。

TypeScript 复制代码
type Method = 'GET' | 'POST';
function request(url: string, method: Method) {
    if (method === 'GET'){
        method;
    }
    else if (method === 'POST'){
        method;
    }
    else {
        const n: never = method;
    }
}

假如后来有一天你修改了 Method 的类型:

TypeScript 复制代码
type Method = 'GET' | 'POST' | 'PUT';

然而你忘记同时修改 request 方法中的控制流程,这时候 else 分支的 method 类型就会产生一个编译错误。

然后我们仅添加一个else if分支就可以解决该编译错误

TypeScript 复制代码
type Method = 'GET' | 'POST' | 'PUT';
function request(url: string, method: Method) {
    if (method === 'GET'){
        method;
    }
    else if (method === 'POST'){
        method;
    }
    else if (method === 'PUT'){
        method;
    }
    else {
        const n: never = method;
    }
}

通过这个方式,我们可以得出一个结论:使用 never 避免出现新增了联合类型没有对应的实现,目的就是写出类型绝对安全的代码。

与 void 的差异

在 TypeScript 中,void 和 never 之间的区别如下:

  • void:表示没有任何类型。通常用于标识函数没有返回值或一个表达式的值为 undefined 或 null。void 类型在非严格模式下允许被赋值为 null 或 undefined。
  • never:表示永远不存在的值的类型。通常用于表示函数永不返回(比如抛出异常)或一个表达式永远不会有结果。never 类型不能被赋值为任何类型,除了 never 本身。

综上所述,void 表示没有任何类型,可以包括 undefined 或 null,而 never 表示永远不存在的值,通常表示函数永不返回或某些异常情况。

相关推荐
一楼的猫2 小时前
从工具链视角对比:番茄作家助手 vs 第三方写作辅助方案
java·服务器·开发语言·前端·学习·chatgpt·ai写作
掘金一周2 小时前
想换一辆电车,JYM有什么推荐 | 沸点周刊 5.21
前端·人工智能·后端
Nian.Baikal2 小时前
Cesium 3D Tiles 加载与优化实战
前端·cesium
KaMeidebaby3 小时前
卡梅德生物技术快报|噬菌体肽库展示技术构建 Mhp168‑Hsp70 定向随机肽库:流程、质控与数据结果
前端·数据库·其他·百度·新浪微博
lchcy3 小时前
前端实现单点登录(SSO登录)
前端
卷帘依旧3 小时前
SPA下的路由模式详解
前端
环信4 小时前
2026年开发者选择即时通讯厂商应注意的几点
前端
卷帘依旧4 小时前
Generator 全面解析 + async/await 深度对比
前端·javascript
yqcoder4 小时前
数据劫持的双雄:深入解析 Object.defineProperty 与 Proxy
开发语言·前端·javascript
lichenyang4534 小时前
鸿蒙聊天 Demo 练习 03:接入 Next.js 后端接口,实现真机前后端联调
前端