首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

TypeScript 基础类型:原始类型、对象类型数组类型、元组类型、枚举类型联合类型

TypeScript 强大类型系统使得开发者能够更轻松地编写可维护、可扩展代码。本文将详细介绍 TypeScript 基础类型,包括原始类型、对象类型数组类型、元组类型、枚举类型联合类型。...原始类型TypeScript ,有以下几种原始类型:数字类型数字类型用于表示整数或浮点数。可以使用 number 关键字来声明数字变量。...// 字符串数组元组类型元组类型用于表示一个固定长度类型数组。...类型推断类型断言TypeScript 具有强大类型推断能力,它可以根据上下文自动推断变量类型。例如,如果我们在定义变量时直接赋值,TypeScript 可以推断出变量类型。...总结本文详细介绍了 TypeScript 基础类型,包括原始类型、对象类型数组类型、元组类型、枚举类型联合类型等方面。

32630

TypeScript 数组类型定义

TypeScript 声明初始化数组也很简单,和声明数字类型字符串类型变量也差不多,只不过在指定数组类型时要在类型后面加上一个括号 [] 语法格式 const array_name: dataype...array: Array = ['孟浩然', 99]; 除了使用括号 [] 方法来声明数组,你还可以使用 数组泛型 来定义数组 语法格式 const array_name..., val2, val3],[v1, v2, v3]]; // 等同于 const array_name: datatype[][] = [[val1, val2, val3]]; 多维数组类型 TypeScript...注意: 以下示例类型数组,则会限制内层数组元素数量 Array : 表示内层数组元素是 string 类型,限制元素数量是 1 个,输入多个会报错 const test3...个 建议: 在定义数组类型时候使用数组泛型定义,这样显得更直观一点 Tuple 元组类型(元组类型允许表示一个已知元素数量类型数组

5.3K40
您找到你想要的搜索结果了吗?
是的
没有找到

TypeScript-数组元祖类型

前言介绍其基本概念、语法特性以及如何开始使用它来构建类型安全JavaScript应用程序。无论您是新手还是有经验开发者,都能在这篇文章中找到有关TypeScript重要信息实用技巧。...数组类型方式一需求:要求定义一个数组, 这个数组中将来只能存储 数值 类型数据:let val: Array;val = [1, 3, 5];console.log(val);图片如上代码含义为表示定义了一个名称叫做...val 数组, 这个数组中将来只能够存储 字符串 类型数据,错误示例如下:let val: string[];val = [1, 'b', 'a'];console.log(val);图片联合类型...这个数组中将来可以存储 任意 类型数据,没有错误示例元祖类型TS 元祖类型其实就是数组类型扩展,元祖用于保存 定长, 定数据类型 数据let val: [string, number, boolean...大家点赞支持一下哟~ 我正在参与2023腾讯技术创作特训营第二期有奖征文,瓜分万元奖池键盘手表图片

16730

Typescript:可区分类型联合模式

今天,让我们深入了解 TypeScript 中一个有趣模式,它将让你大开眼界!这个模式被称为辨识类型联合或辨识联合类型。在深入探讨这个模式之前,让我们先了解问题。...: { message: string };};我创建了一个名为 PokemonState 类型,其中包含 status、具有特定属性 pokemon 带有消息 error。...验证,因为可能未定义属性,Pokemon 函数存在错误。...TypeScript 类型安全验证在这里!就像我说,pokemon error 取决于 state。我们可以在函数创建一些逻辑来验证每个状态并定义我们是否有这些属性。但这不是最好解决方案。...这种模式根据一个共同属性将类型分离,使 TypeScript 理解到它是类型安全。我喜欢这种模式,以及 TypeScript 如何验证使我们代码更清晰易懂。就是这样!

14510

论编程界日经问题:到底如何区分静态类型动态类型、强类型类型

由 ChatGPT 生成文章摘要 博主在本文中探讨了编程界常见问题,即如何区分静态类型动态类型,强类型类型。他指出,由于这些概念本身没有明确定义,导致人们很难就此达成一致共识。...在强类型类型定义,强类型语言常常会直接出错或编译失败,而弱类型语言会进行隐式转换或产生意料之外结果。根据这个定义,Python被归类为强类型语言。...最后,博主表示这种讨论对工程开发实际意义并不大。 论编程界日经问题:到底如何区分静态类型动态类型、强类型类型?...str 类型相加导致,Python 不知道应该如何将这两种类型相加。...但是想想 void* reinterpret_cast,想想数组传参时指针弱化,他们都证明了 C C++ 会随时进行隐式类型转换,而这种隐式类型转换在 C C++ 仍然是无处不在,这也是它们被称为弱类型语言最好佐证

27140

TypeScript 类型注解类型推断

一、类型注解(Type annotation) 所谓类型注解,就是人为为一个变量指定类型,例如: const a: number = 123; 在 vscode 鼠标移入 a 出现提示,冒号后面就是类型注解...当不添加类型注解时,TypesScript 也能知道变量 a 是一个数字,这就是 TypeScript 类型推断: ?...二、类型推断(Type inference) 所谓类型推断就是 TypeScript 可以通过变量值倒推变量类型,因此在绝大部分情况下,我们是不需要去写类型注解 但有些情况类型推断是无法推断变量类型...,例如函数参数: function getSum(a, b) { return a + b; } const num = getSum(1, 2); 上面代码参数 a,b 就无法类型: ?...从而也导致了 num 类型不能判断: ?

1.1K30

TypeScript类型断言

本文是关于 TypeScript type assertions ,它与其他语言中类型强制转换有相似之处,并通过 as 运算符执行。...在 B 行,我们看到此类型不允许访问任何属性。 在 C 行,我们用类型断言(运算符 as)告诉 TypeScript data 是一个Array。现在就可以访问属性 .length 了。...类型断言是不得已方法,应尽可能避免。他们(暂时)删除了静态类型系统为我们提供安全网。 注意,在 A 行,我们还覆盖了 TypeScript 静态类型,不过是通过类型注释完成。...类型断言替代语法 TypeScript 对于类型断言有另一种“尖括号”语法: 1>data 该语法已经过时,并且与 React JSX 代码(在 .tsx 文件)不兼容。...示例:声明一个接口 为了访问任意对象 obj 属性 .name,我们暂时将 obj 静态类型更改为 Named(A行B行)。

3.7K40

TypeScript类型断言-类型声明转换

TS并不能判断在使用联合类型时具体是那种类型?当我们不知道是什么类型情况下要使用某个类型特有的属性或者方法,那么就可以用断言来实现,它实际上是对编辑器做了提前告知行为,但是并不能保证运行中报错。...主要有两种方式来实现,具体如下:断言形式(1)尖括号形式语法:+value,尖括号填写具体类型。...;let length:number = (anyValue).length;//0使用断言虽然能避免编译报错,但是却避免不了运行报错type ClaaM = number |...但是编译成JS后,运行过程中就报错了,如下:所以除非确切知道变量数据类型,否则不要使用类型断言,这是因为类型断言会让 TypeScript 编译器将变量当做指定类型,而不管它实际类型,在程序运行时可能有类型错误...表示,它用来断定某变量一定不是 null undefined。

32910

TypeScript 顶级类型:any unknown

翻译:疯狂技术宅 作者:Dr. Axel Rauschmayer 正文共:2525 字 预计阅读时间:10 分钟 ? 在 TypeScript,any unknown 是包含所有值类型。...在本文中,我们将会研究它们是怎样工作。 ---- TypeScript 两种顶级类型 any unknown 在 TypeScript 是所谓“顶部类型”。...通常,类型是包含了其相关类型系统中所有可能[值]类型。 也就是说,当把类型看作是值集合时,any unknown 是包含所有值集合。...value; // 通常,`value` 类型签名必须包含 .propName value.propName; // 通常只允许带有索引签名数组类型 value...): any; 在 unknown 类型出现之前,JSON.parse() 就已经被添加到了 TypeScript

2.4K20

TypeScript-枚举成员类型联合类型

TypeScript-枚举成员类型联合类型枚举成员类型可以把 枚举成员 当做 类型 来使用正确示例:enum Gender { Male, Female}interface TestInterface..., 所以会报错注意点由于数字枚举本质就是数值, 所以写一个数值也不会报错如下:enum Gender { Male, Female}interface TestInterface {...age: Gender.Male}class Person implements TestInterface { age: 0}如果是字符串枚举, 那么只能是枚举成员值, 不能是其它值正确示例...TestInterface { age: Gender.Male}图片图片最后本期结束咱们下次再见~ 关注我不迷路,如果本篇文章对你有所帮助,或者你有什么疑问,欢迎在评论区留言,我一般看到都会回复。...大家点赞支持一下哟~ 我正在参与2023腾讯技术创作特训营第二期有奖征文,瓜分万元奖池键盘手表图片

23720

实现TypeScript互斥类型

此时,你会怎么用TypeScript来定义这个类型?本文将带大家实现一个互斥类型来解决这个问题,欢迎各位感兴趣开发者阅读本文。 前置知识 在实现之前,我们需要先来了解几个基础知识。...: string }; never类型TypeScript它有一个特殊类型never,它是所有类型类型,无法再进行细分,也就意味着除了其本身没有类型可以再分配给它。...{}类型 amazing = [];// 报错:amazing是never类型不能分配给[]类型 剔除联合类型属性 有一组联合类型"a" | "b" | "c" | "d",我们想剔除属性bc,在...接下来,我们来梳理下实现思路: 实现一个排除类型,用于从A对象类型剔除B对象类型属性,并将排除后属性类型设为never,得到一个新对象类型。...> & T); 注意:为了类型可复用性,我们使用了泛型,对此不熟悉开发者请移步:TypeScript中文网——泛型 测试用例 我们将文章开头所说问题代入上述实现代码,看一下它能否将其解决,如下所示

3.1K40

TypeScript】TS类型断言-类型声明转换(七)

TS并不能判断在使用联合类型时具体是那种类型?当我们不知道是什么类型情况下要使用某个类型特有的属性或者方法,那么就可以用断言来实现,它实际上是对编辑器做了提前告知行为,但是并不能保证运行中报错。...主要有两种方式来实现,具体如下:断言形式(1)尖括号形式语法:+value,尖括号填写具体类型。...;let length:number = (anyValue).length;//0使用断言虽然能避免编译报错,但是却避免不了运行报错type ClaaM = number |...但是编译成JS后,运行过程中就报错了,所以除非确切知道变量数据类型,否则不要使用类型断言,这是因为类型断言会让 TypeScript 编译器将变量当做指定类型,而不管它实际类型,在程序运行时可能有类型错误...19;const obj:Object = {};(obj).name = 'zhangsan';(obj).age = 19;(4)调用函数时将参数返回值断言成精确值function

31410

【OpenHarmony】TypeScript 语法 ② ( 基础数据类型 | 布尔类型 | 数字类型 | 字符串类型 | 数组类型 | 元组类型 | 枚举类型 | 未知类型 | 联合类型 )

基础数据类型 ; 1、布尔类型 TypeScript 布尔值类型 使用 " boolean " 表示 , 取值 true 或 false ; 代码示例 : // 声明 布尔类型 变量 let...TypeScript 代码 : 3、字符串类型 TypeScript 字符串类型 使用 " string " 表示 , 可以将字符串放在 双引号 "" , 也可以放在 单引号 '' ..." + str + " , str2 : " + str2); 在 https://ts.nodejs.cn/play 运行 TypeScript 代码 : 4、数组类型 TypeScript ...代码 : 5、元组类型 TypeScript 元组类型 可用于描述 已知 元素数量 元素类型 数组 , 数组 元素类型可以不同 ; 代码示例 : // 元组类型 // 为元组赋值时 ,...元素数量种类必须与声明类型一一对应 let person: [string, number] = ['Tom', 18] // 控制台打印上述变量 console.log("person :

15410

TypeScript-neverobject类型类型断言概述

前言TypeScript "never" 类型表示一个永远不会发生正常结束函数返回值类型,通常在异常处理或无限循环中使用。这有助于标识代码潜在问题错误流程。"...object" 类型用于表示非原始类型(如字符串、数字、布尔等)对象。它允许你定义具有不同属性方法对象,但无法访问对象具体属性,因此谨慎使用,以避免类型错误。"...never" 用于处理异常情况,而 "object" 用于通用对象表示。正确使用它们有助于提高代码可读性类型安全性。...会报错// obj = 123;obj = {name: "BNTang", age: 18};console.log(obj);类型断言概述TS 类型断言和其它编程语言 类型转换 很像,可以将一种类型强制转换成另外一种类型类型断言就是告诉编译器..., 此时我们就可以通过类型断言将 any 类型转换成 string 类型, 使用字符串类型相关方法了方式一let str: any = "yby6";let len = (str).

20620

TypeScript高级类型工具类型及关键字

本文主要帮助理解 TypeScript 高级类型及工具类型。在实际使用 TypeScript 开发过程,得益于这些高级类型于工具类型,我们可以更方便构建出我们需要类型。...比如说:我们在后台登陆信息认证构建了一个用户,它是 LoginUser 类型, 它包含了:“name 用户名”、“email 邮箱”、“roles:角色”等多个信息,其中 name 可能不是必选项。...一、高级类型 泛型 泛型可以理解为一个变量,这个变量值是一个类型函数参数一样。...T, K 相同类型构造一个新类型 // type Extract = T extends U ?...T 处理过程某个部分抽离出来当做类型变量 type Unpacked = T extends (infer U)[] ?

2.1K30
领券