温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

TS中never,void,unknown类型怎么使用

发布时间:2023-05-05 10:24:26 来源:亿速云 阅读:131 作者:iii 栏目:开发技术

这篇文章主要讲解了“TS中never,void,unknown类型怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“TS中never,void,unknown类型怎么使用”吧!

    TS 中 never,void,unknown类型详解

    一. never

    never 类型是 TypeScript 中的底层类型。它在以下情况中很好的被使用:

    • 一个从来不会有返回值的函数,即死循环(如:如果函数内含有 while(true) {});

    • 一个总是会抛出错误的函数(如:function foo() { throw new Error('Not Implemented') }foo 的返回类型是 never);

     function foo(): never {//永远不会返回结果 // 死循环 while(true) {}
     }
    function bar(): never {throw new Error()
     }

    never 仅能被赋值给另外一个 never 类型,因此可以用它来进行编译时的全面的检查

    举例:

    function foo(x: string | number): boolean {if (typeof x === 'string') {return true;} else if (typeof x === 'number') {return false;}// 如果不是一个 never 类型,这会报错:// - 不是所有条件都有返回值 (严格模式下)// - 或者检查到无法访问的代码// 但是由于 TypeScript 理解 `fail` 函数返回为 `never` 类型// 它可以让你调用它,因为你可能会在运行时用它来做安全或者详细的检查。return fail('Unexhaustive');
    }
    function fail(message: string): never {throw new Error(message);
    }

    二. void(空值)

    JavaScript 没有空值(void)的概念,在 TypeScript 中,表示没有任何返回值的函数

    // 没有返回值的函数,其返回值类型为 void
    function alertName(): void { alert('My name is Tom'); }

    当然你也可以声明一个变量为void ,但你只能将它赋值为 undefined 和 null:

    let unusable: void = undefined;

    void函数中使用场景:

    // 如果什么都不写,此时,add 函数的返回值类型为: void
    const add = () => { //
    }
    // 如果return之后什么都不写,此时,add 函数的返回值类型为: void
    const add = () => {  return 
    }
    const add = (): void => {// 此处,返回的 undefined 是 JS 中的一个值return undefined
    }
    // 这种写法是明确指定函数返回值类型为 void,与上面不指定返回值类型相同
    const add = (): void => {// 
    }

    三. unknown

    unknown是TypeScript中比较特殊的一种类型,它用于描述类型不确定的变量。这与any类型相似,但更安全,因为对未知值做任何事情都是不合法的。

    function foo() {return 'abc'
    }
    function bar() {return 123
    }
    // unknown类型只能赋值给any和unknown类型
    // any类型可以赋值给任意类型
    let flag = true
    let result: unknown // 最好不要使用any
    if (flag) {result = foo()
    } else {result = bar()
    }
    let message: string = result //报错
    let num: number = result //报错
    let num1: unknown = result
    let num2: any = result
    console.log(result)

    需要通过类型范围缩小类型断言,才能在 unknown 类型上进行任何操作

    举例:

    let value: unknown = 123;
    console.log(++value )//error:'value' is of type 'unknown'.
    console.log(++(value as number) )

    unknown 除了与 any 以外, 与其它任何类型组成的联合类型最后都是 unknown 类型

    举例:

    TS中never,void,unknown类型怎么使用

    TS中never,void,unknown类型怎么使用

    unknown 与其它任何类型组成的交叉类型最后都是其它类型

    举例:

    TS中never,void,unknown类型怎么使用

    当然还有一些别的unkonw特性比如:

    1.只能对 unknown 类型进行 相等 或 不等 操作, 不能进行其它操作;2.unknown 类型的值不能访问创建实例的属性, 方法;3.使用映射类型时, 如果遍历的是 unknown 类型, 那么不会映射任何属性。

    四. never与void的区别

    1.void 表示没有任何类型,never 表示永远不存在的值的类型。

    2.当一个函数返回空值时,它的返回值为 void 类型,但是,当一个函数永不返回时(或者总是抛出错误),它的返回值为 never 类型。void 类型可以被赋值(在 strictNullChecking 为 false 时),但是除了never 本身以外,其他任何类型不能赋值给 never

    五. 其他注意事项

    unknown,never 都不允许执行变量的方法以及访问内部属性;

    never是所有类型的子类型;

    补充:TypeScript-unknown类型

    • unknown 类型是 TS3.0 中新增的一个顶级类型, 被称作安全的 any

    任何类型都可以赋值给 unknown 类型:

    let value: unknown;
    value = 123;
    value = "abc";
    value = false;

    如果没有类型断言或基于控制流的类型细化, 那么不能将 unknown 类型赋值给其它类型。

    错误示例:

    let value1: unknown = 123;
    let value2: number;
    value2 = value1;

    正确示例:

    let value1: unknown = 123;
    let value2: number;
    value2 = value1 as number;

    let value1: unknown = 123;
    let value2: number;
    if (typeof value1 === 'number') {
        value2 = value1;
    }

    如果没有类型断言或基于控制流的类型细化, 那么不能在 unknown 类型上进行任何操作。

    错误示例:

    let value1: unknown = 123;
    value1++;

    正确示例:

    let value1: unknown = 123;
    (value1 as number)++;

    let value1: unknown = 123;
    if (typeof value1 === 'number') {
        value1++;
    }

    只能对 unknown 类型进行 相等 或 不等 操作, 不能进行其它操作(因为其他操作没有意义)。

    正确示例:

    let value1: unknown = 123;
    let value2: unknown = 123;
    console.log(value1 === value2);
    console.log(value1 !== value2);

    不能进行其它操作(因为其他操作没有意义), 虽然没有报错, 但是不推荐, 如果想报错提示, 可以打开严格模式("strict": true):

    TS中never,void,unknown类型怎么使用

    let value1: unknown = 123;
    let value2: unknown = 123;
    console.log(value1 >= value2);

    unknown 与其它任何类型组成的交叉类型最后都是其它类型:

    type MyType = number & unknown;
    type MyType = unknown & string;

    unknown 除了与 any 以外, 与其它任何类型组成的联合类型最后都是 unknown 类型:

    type MyType1 = unknown | any;
    type MyType2 = unknown | number;
    type MyType3 = unknown | string | boolean;

    never 类型是 unknown 类型的子类型:

    type MyType = never extends unknown ? true : false;

    keyof unknown 等于 never:

    type MyType = keyof unknown;

    unknown 类型的值不能访问创建实例的属性, 方法:

    TS中never,void,unknown类型怎么使用

    class="language-typescript">class Person {
        name: string = 'BNTang';
        say(): void {
            console.log(`name = ${this.name}`);
        }
    }
    let p: unknown = new Person();
    p.say();
    console.log(p.name);

    使用映射类型时, 如果遍历的是 unknown 类型, 那么不会映射任何属性:

    type MyType<T> = {
        [P in keyof T]: any
    }
    type res = MyType<unknown>

    感谢各位的阅读,以上就是“TS中never,void,unknown类型怎么使用”的内容了,经过本文的学习后,相信大家对TS中never,void,unknown类型怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI