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

TypeScript一些知识点

TypeScript的原始类型 TypeScript常见原始类型有: boolean string number bigint symbol undefined null void 枚举类型 字面量类型...看一个稍微复杂一点的例子: const a: 'a' = 'a'; // 注意这里的类型使用了 'a' 而不是string, 如果是string则不能用在对象中作为属性 const b: unique...add的类型,然后再给实现,所以实现的参数和返回类型一定要满足定义中的所有情况,上述实现中x使用了any类型,如果是number | string,则不符合定义函数中的任意一项,所以也会报错。...类 TypeScript的类与JavaScript的类大多数语法都是类似的,但TypeScript对类的一下功能做了扩充,如接口实现、泛型类等。...protected: 在当前类和派生类内部可以访问,不允许当前类外部(如创建的对象)访问。 private: 只有当前类的内部可以访问。

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

    TypeScript 官方手册翻译计划【二】:普通类型

    在学习类型本身的同时,我们也会学习如何在某些地方使用这些类型去组成新的结构。 首先,我们先来回顾一下编写 JavaScript 或者 TypeScript 代码时最基础和最常用的类型。...它可以确保对象的所有属性都被赋予了一个字面量类型,而不是采用类似 string 或者 number 这样较为通用的类型。...枚举 枚举是 TypeScript 添加到 JavaScript 中的一项特性。它允许描述一个值,该值可以是一组可能的命名常量中的一个。...与大多数的 TypeScript 特性不同,枚举不是在类型层面添加到 JavaScript 中的,而是添加到语言本身和它的运行时中。...BigInt ES2020 引入了 BigInt,用于表示 JavaScript 中非常大的整数: // 通过 BigInt 函数创建大整数 const oneHundred: bigint = BigInt

    2.3K20

    如何在TypeScript中使用基本类型

    这种组合允许开发人员使用完整的 JavaScript 生态系统和语言功能,同时还添加可选的静态类型检查、枚举数据类型、类和接口。...要在 macOS 或 Ubuntu 18.04 上安装,请按照如何在 macOS 上安装 Node.js 和创建本地开发环境或如何在 Ubuntu 18.04 上安装 Node.js 的使用 PPA 安装部分中的步骤进行操作...我们也可以在 TypeScript Playground 中尝试这些好处。 本教程中显示的所有示例都是使用 TypeScript 4.2.2 版创建的。...我们创建变量并为其分配一个值,但不指定类型,如下所示: const language = { name: "JavaScript" }; 在此代码块中,语言是一个对象,其中包含属性名称的字符串值。...在 TypeScript 代码库中工作时,这些类型将经常使用,并且是创建更复杂的自定义类型的主要构建块。

    3.7K10

    Web前端面试敲重点知识,14个TypeScript核心基础面试题和答案

    6、TypeScript 中声明变量有哪些不同的关键字? 7、如何书写带有类型注释的函数 ? 8、如何在 TypeScript 中创建对象 ? 9、如何在 TypeScript 中指定可选属性 ?...函数是执行特定代码的代码块 函数可以有选择地接受一个或多个参数,处理它们,并有选择地返回一个值。 image.png 8、如何在 TypeScript 中创建对象 ?...它们类似于数组,有时也称为关联数组 但是,数组使用数字来索引值,而对象允许使用任何其他类型作为键 image.png 9、如何在 TypeScript 中指定可选属性 ? 通过添加 ?...对象类型可以具有零个或多个可选属性,在属性名称之后 image.png 10、说说枚举在 TypeScript 中是如何工作的 ?...在 TypeScript 中,您可以将任何数据和函数创建为简单对象,而无需创建包含类。 因此 TypeScript 不需要静态类,单例类只是 TypeScript 中的一个简单对象。

    11.5K10

    《现代Typescript高级教程》枚举和泛型

    现代JavaScript高级小册 深入浅出Dart 现代TypeScript高级小册 枚举和泛型 接下来我们将学习TypeScript 中的两个重要主题:枚举(Enums)和泛型(Generics)。...这两个特性能大大提高代码的可重用性和安全性。 枚举 枚举是 TypeScript 中一种特殊的数据类型,允许我们为一组数值设定友好的名字。枚举的定义使用 enum 关键字。...泛型允许我们在定义函数、类或接口时使用类型参数,这些类型参数在使用时可以被动态地指定具体的类型。 以下是泛型在 TypeScript 中的几个常见应用场景: 1....通过指定类型参数为number和string,我们创建了一个具体的pair对象,它的first属性类型为number,second属性类型为string。 3....通过在创建类的实例时显式指定类型参数为number,我们创建了一个具体的container对象,它的value属性类型为number,并可以使用getValue方法获取该值。

    23710

    【TypeScript 演化史 — 第七章】映射类型和更好的字面量类型推断

    TypeScript 2.1 引入了映射类型,这是对类型系统的一个强大的补充。本质上,映射类型允许w咱们通过映射属性类型从现有类型创建新类型。根据咱们指定的规则转换现有类型的每个属性。...转换后的属性组成新的类型。 使用映射类型,可以捕获类型系统中类似 Object.freeze() 等方法的效果。冻结对象后,就不能再添加、更改或删除其中的属性。...来看看如何在不使用映射类型的情况下在类型系统中对其进行编码: interface Point { x: number; y: number; } interface FrozenPoint {...对于希望在应用程序中冻结的每种类型的对象,咱们就必须定义一个包装器函数,该函数接受该类型的对象并返回冻结类型的对象。没有映射类型,咱们就不能以通用的方式静态地使用 Object.freeze()。...该方法返回一个新对象,该对象只包含咱们选择的属性。可以使用Pick对该行为进行构建,正如其名称所示。

    3.8K40

    TS 进阶 - 类型基础

    在 TypeScript 中,symbol 类型并不具有这一特性,多个具有 symbol 类型的对象,它们的 symbol 类型指的都是 TypeScript 中的同一个类型。...在 JavaScript 中,可以用 Symbol.for 方法来复用已创建的 Symbol,如 Symbol.for('Cell') 会首先查找全局是否已经有使用 Cell 作为 key 的 Symbol...在 TypeScript 中,要引用已创建的 unique symbol 类型,需要使用类型查询操作符 typeof,如 typeof sym1。...TypeScript 中可以同时使用字符串枚举值和数字枚举值: enum Mixed { Num = 1, Str = 'str', } 枚举和对象的重要差异在于,对象是单向映射的,只能从键映射到键值...,同时,其编译产物中并不会存在一个额外的辅助对象,对枚举成员的访问会被直接内联替换为枚举的值。

    1.8K50

    【TypeScript】010-类型别名、字符串字面量类型、元组、枚举

    我们使用 type 创建类型别名。...3、元组 数组合并了相同类型的对象,而元组(Tuple)合并了不同类型的对象。 元组起源于函数编程语言(如 F#),这些语言中会频繁使用元组。...未手动赋值的枚举项会接着上一个枚举项递增。...在这种情况下,当前枚举成员的值为上一个枚举成员的值加 1。但第一个枚举元素是个例外。如果它没有初始化方法,那么它的初始值为 0。 枚举成员使用常数枚举表达式初始化。...当一个表达式满足下面条件之一时,它就是一个常数枚举表达式: 数字字面量 引用之前定义的常数枚举成员(可以是在不同的枚举类型中定义的)如果这个成员是在同一个枚举类型中定义的,可以使用非限定名来引用

    6100

    【TypeScript 演化史 -- 7】映射类型和更好的字面量类型推断

    . ---- 为了保证的可读性,本文采用意译而非直译。 TypeScript 2.1 引入了映射类型,这是对类型系统的一个强大的补充。本质上,映射类型允许w咱们通过映射属性类型从现有类型创建新类型。...根据咱们指定的规则转换现有类型的每个属性。转换后的属性组成新的类型。 使用映射类型,可以捕获类型系统中类似 Object.freeze() 等方法的效果。...来看看如何在不使用映射类型的情况下在类型系统中对其进行编码: interface Point { x: number; y: number; } interface FrozenPoint {...对于希望在应用程序中冻结的每种类型的对象,咱们就必须定义一个包装器函数,该函数接受该类型的对象并返回冻结类型的对象。没有映射类型,咱们就不能以通用的方式静态地使用 Object.freeze()。...该方法返回一个新对象,该对象只包含咱们选择的属性。可以使用 Pick 对该行为进行构建,正如其名称所示。

    2.9K10

    类型即正义:TypeScript 从入门到实践(一)

    类型类似,我们将在之后的讲解中逐渐用到其中的类型。...这里的 interface 我们还没用提到,我们将马上在后面讲到,可以理解它类似 JS 中的对象,用来组织一组类型,就比如我们这里 todoList 中单个元素实际上是包含四个属性的对象,其中前三个属性为...propName: string]: any; } 使用类似上面 JS 中的动态属性赋值的方式我们就可为 Todo 接口加上多余属性检查,这里我们将其注解为一定拥有 isCompleted 属性,...Enum 枚举是 TS 中独有的概念,在 JS 中没有,主要用于帮助定义一系列命名常量,常用于给一类变量做类型注解,它们的值是一组值里面的某一个,比如我们应用中参与创建待办事项的用户只有五个人,那么在创建待办事项时...)和枚举(Enum),接口主要是对对象等多属性元素进行类型注解,而枚举是 TS 中独有的一个概念,在 JS 中没有,主要用于帮助定义一系列命名常量,常用于给一类变量做类型注解,它们的值是一组值里面的某一个

    2.6K20

    【TypeScript 4.5】003-第 3 章 常用类型

    代码分析 // printCoord 参数的类型是一个对象 // 对象的两个属性可以使用逗号(,)或分号(;)分隔 function printCoord(pt: { x: number; y: number...一种是可以改变,一种是不可改变 这反应在 TypeScript 就是如何为文字创建类型。...toFixed) } 十三、枚举 1、概述 枚举是 TypeScript 添加到 JavaScript 中的一项功能! 这个值可能是一组命名常量之一!...与大多数 TypeScript 功能不同 这个不是 JavaScript 类型级别里面添加的内容 而是添加到 TypeScript 语言和运行时的内容 只有确定确实需要枚举来做些事情的时候 否则没有必要使用它...1、概述 JavaScript 一些不太常用的原语在 TypeScript 中也实现了 我们来学习两个:bigint(非常大的整数) 和 symbol(全局唯一引用)。

    8210

    TypeScript 简介及编码规范

    TypeScript 是什么 TypeScript 是一种由微软开发的自由和开源的编程语言。它是 JavaScript 的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程。...= {...person, age: 31}; // 获取除了某些项外的其它项 let {name, ...rest} = person; TypeScript Interface 在面向对象语言中...TypeScript 中的接口是一个非常灵活的概念,除了可用于对类的一部分行为进行抽象以外,也常用于对「对象的形状(Shape)」进行描述。...TypeScript Class 在面向对象语言中,类是一种面向对象计算机编程语言的构造,是创建对象的蓝图,描述了所创建的对象共同的属性和方法。...:number } = { x:123 }; 通常使用 undefined( 而不是返回一个类似于 { valid:boolean, value?

    10.6K40

    Typescript基础语法

    typescript与javascript typescript是一个js的超集,个人理解为包装了面向对象编程逻辑的语法糖,所以一般使用typescript的语言来编写代码,然后再使用typescript...类通过implements关键字,指定要实现的接口,需要类中具备满足接口定义的成员 创建类对象使用new 调用构造函数 interface Man{ fullName: string;...readonly typescript中的readonly代表修饰成员为只读,不可修改(类似java的final) 存取器 typesceipt中提供了默认存取器(如java的读屏障、写屏障),通过存取器...还支持创建一个可以指代多种类型的类型,通过|运算符,即可使用不同类型创建一个联合类型,代表当前变量为其中之一,如 let a : string | number; 类型别名 typescript还支持为类型定义别名...type sTringNNumber = string | number; let a : tString; 枚举 与java类似,使用enum关键字创建枚举,默认枚举值为整数,不指定整数值默认从0

    1.5K20

    深入理解 TypeScript 中的 Keyof 运算符,让你的代码更安全、更灵活!

    一、如何定义 KeyOf 运算符 在 TypeScript 中,keyof 运算符用于获取用户定义的值。它主要用于泛型,格式类似于联合运算符及其属性。keyof 运算符会检索用户指定的值的索引。...这种运算符可以用于如集合和类等对象,通过键值对来存储和检索数据。使用 map 实例对象的 object.keys() 方法,我们可以获取存储在内存中的键。...KeyOf 运算符创建联合类型 在 TypeScript 中,当我们在具有显式键的对象类型上使用 keyof 运算符时,它会创建一个联合类型。...类型安全的配置对象: 当我们处理配置对象时,可以使用 keyof 来确保配置项的名称是预定义的有效值。 通过在对象类型上使用 keyof 运算符,我们可以创建联合类型,从而确保属性访问的类型安全性。...我们使用了 TypeScript 的 Record 实用类型来创建一个映射,该映射将 Status 枚举的值映射到具有特定结构的对象。

    23910

    TypeScript学习笔记(四)—— TypeScript提高

    1.2、基本使用 通过type可以定义类似接口的类型,如下示例中User是一个自定义的类型,tom被User约束: type User={ name:string; age:number...未手动赋值的枚举项会接着上一个枚举项递增。...在这种情况下,当前枚举成员的值为上一个枚举成员的值加 1。但第一个枚举元素是个例外。如果它没有初始化方法,那么它的初始值为 0。 枚举成员使用常数枚举表达式初始化。...当一个表达式满足下面条件之一时,它就是一个常数枚举表达式: 数字字面量 引用之前定义的常数枚举成员(可以是在不同的枚举类型中定义的)如果这个成员是在同一个枚举类型中定义的,可以使用非限定名来引用 带括号的常数枚举表达式...7.1、简单的例子 首先,我们来实现一个函数 createArray,它可以创建一个指定长度的数组,同时将每一项都填充一个默认值: function createArray(length: number

    2.5K10

    TypeScript基础常用知识点总结

    TypeScript 使用举例: 方式一是通过全局 tsc 命令编译 TypeScript 代码 创建一个目录: mkdir ts-practice cd ts-practice 我们创建一个test.ts...创建 Map对象并对其进行操作 TypeScript 使用 Map 类型和 new 关键字来创建 Map: //创建 Map对象 let myMap = new Map(); // 设置 Map 对象用...TypeScript—类 TypeScript 是面向对象的 JavaScript。类描述了所创建的对象共同的属性和方法。...(Days[0]); // Sun 我们也可以给枚举项手动赋值,未手动赋值的枚举项会接着上一个枚举项递增: enum Days {Sun = 7, Mon = 1, Tue, Wed, Thu, Fri...通常我们会把声明语句放到一个单独的文件(如jQuery.d.ts)中,这就是声明文件,声明文件必需以 .d.ts 为后缀。

    4.9K30

    TypeScript

    TypeScript 标准库声明 标准库就是内置对象所对应的声明 当tsconfig.json中target为“es5”时,const h: symbol = Symbol();会报错,因为es5标准中没有...一个标准库中,所以lib中需要追加["DOM"] image.png image.png 六、TypeScript 中文错误消息 可以使用中文的错误消息 yarn tsc --locale zh-CN...123; export {};//作为模块导出,确保跟其他示例没有冲突 八、TypeScript Object类型 TypeScript中的Object类型并不单指普通的对象类型,而是泛指非原始类型,...,使用常量枚举则可以移除 image.png 十二、TypeScript 函数类型 // 函数类型 export {}; //确保和其他示例成员没有冲突 // 不确定参数放在最后 使用?...", }); 接口就是用来约束对象的结构,一个对象去实现一个接口,必须要拥有这个接口中所有的成员 十七、TypeScript 接口补充 // 定义接口 interface Post { title:

    1.8K41

    深度讲解TS:这样学TS,迟早进大厂【16】:枚举

    未手动赋值的枚举项会接着上一个枚举项递增。...前面我们所举的例子都是常数项,一个典型的计算所得项的例子: enum Color {Red, Green, Blue = "blue".length}; 上面的例子中,"blue".length 就是一个计算所得项...在这种情况下,当前枚举成员的值为上一个枚举成员的值加 1。但第一个枚举元素是个例外。如果它没有初始化方法,那么它的初始值为 0。 枚举成员使用常数枚举表达式初始化。...当一个表达式满足下面条件之一时,它就是一个常数枚举表达式: 数字字面量 引用之前定义的常数枚举成员(可以是在不同的枚举类型中定义的)如果这个成员是在同一个枚举类型中定义的,可以使用非限定名来引用...带括号的常数枚举表达式 +, -, ~ 一元运算符应用于常数枚举表达式 +, -, *, /, %, >, >>>, &, |, ^ 二元运算符,常数枚举表达式做为其一个操作对象。

    37820

    4000字讲清 《深入理解TypeScript》一书 【基础篇】

    或者,你也可以创建一个针对于特定库的声明文件,如为 jquery 创建 jquery.d.ts 文件。...几乎排名前 90% 的 JavaScript 库的声明文件存在于 DefinitelyTyped 这样一个仓库里,在创建自己定义的声明文件之前,我们建议你先去仓库中寻找。...虽然创建一个声明文件这种快速但是不好的方式是减小使用 TypeScript 初始阻力的重要步骤。...考虑使用 jquery 的用例,你可以非常简单快速的为它创建一个定义: declare var $: any; 有时候,你可能想给某些变量一些明确的定义(如:jquery),并且你会在类型声明空间中使用它...如果在你的参数里,不止拥有一个泛型,你应该使用一个更语义化名称,如 TKey 和 TValue (通常情况下,以 T 作为泛型的前缀,在其他语言如 C++ 里,也被称为模板) 变体 对类型兼容性来说,变体是一个利于理解和重要的概念

    1.9K30
    领券