首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    如何利用 TypeScript 的判别联合类型提升错误处理与代码安全性

    TypeScript中的魔法衣橱整理术 在TypeScript中,判别联合类型(Discriminated Unions)使用一个共同的属性,称为判别属性(discriminant),来区分联合类型中的不同类型...错误用法: handleMessage({ type: 'text', sender: 'User123' }); // TypeScript 类型错误:参数 `{ type: "text"; sender...: string; }` 不可赋值给 `Message` 类型。...最后,在第三个例子中,我们错误地将系统消息的属性与图片消息的属性混淆,导致类型错误。 在handleMessage函数中,TypeScript像一个敏锐的分类器。...handleServerError函数利用TypeScript的类型检查来准确处理不同的错误类型,从而提高代码的可读性和可维护性。

    71110

    开心的档之TypeScript 变量声明

    遵循强类型,如果将不同的类型赋值给变量会编译错误,如下实例:var num:number = "hello" // 这个代码会编译错误----类型断言(Type Assertion)类型断言可以用来手动指定一个值的类型...(str2)TypeScript 是怎么确定单个断言是否足够当 S 类型是 T 类型的子集,或者 T 类型是 S 类型的子集时,S 能被成功断言成 T。...:1----类型推断当类型没有给出时,TypeScript 编译器利用类型推断来推断类型。...注意变量声明没有指定类型。因此,程序使用类型推断来确定变量的数据类型,第一次赋值为 2,num 设置为 number 类型。第三行代码,当我们再次为变量设置字符串类型的值时,这时编译会错误。...因为变量已经设置为了 number 类型。error TS2322: Type '"12"' is not assignable to type 'number'.

    1.3K30

    TypeScript 对象的类型-接口

    一、什么是接口 在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型 接口是一系列抽象方法的声明,是一些方法特征的集合,第三方可以通过这组抽象方法调用,让具体的类执行具体的方法...TypeScript 中接口除了可用于对类的一部分行为进行抽象以外,还可用于对「对象的形状(Shape)」进行描述 举个例子: interface Person { name: string;...需要注意的是,一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它类型的子集: interface Person { name: string; age?...索引值可以是数字或字符串 interface Names { [index:number]:string } let list1:Names = ["Faker",1,"Bang"] // 错误元素...// 正确 list2[2] = "ten" // 错误 七、接口继承 接口继承就是说接口可以通过其他接口来扩展自己,Typescript 允许接口继承多个接口,继承使用关键字 extends

    4.6K10

    开心档之TypeScript 变量声明

    TypeScript 变量声明 变量是一种使用方便的占位符,用于引用计算机内存地址。 我们可以把变量看做存储数据的容器。 TypeScript 变量的命名规则: 变量名称可以包含数字和字母。...遵循强类型,如果将不同的类型赋值给变量会编译错误,如下实例: var num:number = "hello" // 这个代码会编译错误 ---- 类型断言(Type Assertion) 类型断言可以用来手动指定一个值的类型...console.log(str2) TypeScript 是怎么确定单个断言是否足够 当 S 类型是 T 类型的子集,或者 T 类型是 S 类型的子集时,S 能被成功断言成 T。...; 执行输出结果为: 1 ---- 类型推断 当类型没有给出时,TypeScript 编译器利用类型推断来推断类型。...注意变量声明没有指定类型。因此,程序使用类型推断来确定变量的数据类型,第一次赋值为 2,num 设置为 number 类型。 第三行代码,当我们再次为变量设置字符串类型的值时,这时编译会错误。

    1.2K20

    开心档之TypeScript 变量声明

    TypeScript 变量声明 变量是一种使用方便的占位符,用于引用计算机内存地址。 我们可以把变量看做存储数据的容器。 TypeScript 变量的命名规则: 变量名称可以包含数字和字母。...遵循强类型,如果将不同的类型赋值给变量会编译错误,如下实例: var num:number = "hello" // 这个代码会编译错误 ---- 类型断言(Type Assertion) 类型断言可以用来手动指定一个值的类型...console.log(str2) TypeScript 是怎么确定单个断言是否足够 当 S 类型是 T 类型的子集,或者 T 类型是 S 类型的子集时,S 能被成功断言成 T。...; 执行输出结果为: 1 ---- 类型推断 当类型没有给出时,TypeScript 编译器利用类型推断来推断类型。...注意变量声明没有指定类型。因此,程序使用类型推断来确定变量的数据类型,第一次赋值为 2,num 设置为 number 类型。 第三行代码,当我们再次为变量设置字符串类型的值时,这时编译会错误。

    84310

    TypeScript学习笔记(二)—— TypeScript基础

    "] = 15 // 类型错误,输出 error TS2322: Type '"google"' is not assignable to type 'number'. // agelist...需要注意的是,类型断言只能够「欺骗」TypeScript 编译器,无法避免运行时的错误,反而滥用类型断言可能会导致运行时错误: interface Cat { name: string;...上面的例子中,数字类型的变量 foo 上是没有 length 属性的,故 TypeScript 给出了相应的错误提示。 这种错误提示显然是非常有用的。...需要注意的是,将一个变量断言为 any 可以说是解决 TypeScript 中类型问题的最后一个手段。 它极有可能掩盖了真正的类型错误,所以如果不是非常确定,就不要使用 as any。...9.2.4、将 any 断言为一个具体的类型 在日常的开发中,我们不可避免的需要处理 any 类型的变量,它们可能是由于第三方库未能定义好自己的类型,也有可能是历史遗留的或其他人编写的烂代码,还可能是受到

    5.9K20

    深度讲解TS:这样学TS,迟早进大厂【08】:对象的类型—接口

    初学者玩转 TypeScript系列,总计 21 期,点赞、收藏、评论、关注、三连支持!...TS系列地址: 21篇文章带你玩转ts # 对象的类型——接口 在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型。...TypeScript 中的接口是一个非常灵活的概念,除了可用于对类的一部分行为进行抽象以外,也常用于对「对象的形状(Shape)」进行描述。...需要注意的是,一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它的类型的子集: interface Person { name: string; age?...如果接口中有多个类型的属性,则可以在任意属性中使用联合类型: interface Person { name: string; age?

    1.2K10

    TypeScript介绍和使用

    从语言类型检查的时机来看 我们所编写的代码在执行层面,按照类型检查的时机来分类,可以分为动态类型和静态类型 动态类型 动态类型是指在运行时才会进行类型检查,这种语言的类型错误往往会导致运行时错误。...静态类型 静态类型是指编译阶段就能确定每个变量的类型,这种语言的类型错误往往会导致语法错误。...另一方面,也使得它的 代码质量参差不齐,维护成本高,运行时错误多。 TypeScript 的类型系统,在很大程度上弥补了 JavaScript 的缺点。...以下代码虽然没有指定类型,但是会在编译的时候报错: let demo = 'hellow world'; demo = 1; // index.ts(2,1): error TS2322: Type...事实上,它等价于: let demo: string = 'hellow world'; demo = 1; // index.ts(2,1): error TS2322: Type 'number'

    1.2K60
    领券