2021.12.13 每天进步一点点: ts变量类型、符号、关键字的整理

本文主要是介绍2021.12.13 每天进步一点点: ts变量类型、符号、关键字的整理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ts变量类型、符号、关键字的整理

      • TS数据类型
        • 布尔值
        • 数字型
        • 字符串型
        • 数组
          • 数字型数组
        • 元组
        • 枚举型
        • any类型
        • void类型
        • undefined类型
        • null类型
        • never类型
        • object类型
        • unknown类型
        • Date类型
        • interface类型
        • 可索引接口类型
        • 继承接口类型
        • 函数类型
        • 泛型T
        • 交叉类型
        • 联合类型
      • TS符号
        • 类型断言
        • 可选属性
      • TS关键字
        • readonly只读


TS数据类型

布尔值
: boolean
数字型
: number

支持二进制,十进制,八进制,十六进制

字符串型
: string

引号可以是"",也可以是’’,或者是模板字符串``

数组
[]
数字型数组
: number[]: Array<number>
元组

包含的元素可以有不同类型的数组

: [string, number]  // 表示第一个元素是字符串类型,第二个元素是数字型
枚举型
enum Color {Red, Green, Blue};

Color是变量类型。{}里面排序方式默认是0, 1, 2, …

有两种用法:

  1. 通过值,获取下标
: Color = Color.Red; // 0: Color = Color.Green; // 1

  1. 通过下标,获取值
: string = Color[0]; // 'Red': string = Color[1]; // 'Green'

也可以更改下标:

enum Color {Red = 1, Green = 4, Blue = 2};: Color = Color.Red; // 1: string = Color[4]; // Green

如果只设置了第一个元素的下标值, 后面的下标值是按照新的下标值往后增加的:

enum Color {Red = 1, Green, Blue};: Color = Color.Green; // 2: Color = Color.Blue; // 3
any类型

任意类型,未知类型,不同类型

: any[] = [1, 'hello', true];
void类型

不属于任何类型。

通常只用于函数没有返回值的时候, 给函数设置为void类型。

function fn(): void {console.log('这个函数没有返回值');
}

如果非要给变量设置为void类型,

则只能给变量赋值为undefined或null;

: void = undefined;: void = null;
undefined类型

一个undefined类型的变量,只能赋值为undefined;

: undefined = undefined;
null类型

一个null类型的变量,只能赋值为null;

: null = null;
never类型

表示该变量用不存在。

用在函数类型时,表示该函数永不存在正常执行的结束点。

官方文档给的用法:

function err(msg): never {throw new Error(msg);
}function noOk(): never {while (true) {// ...}
}
object类型

非原始类型,复杂类型,除了number,string,boolean,symbol,null或undefined之外的类型。

: object = {};
unknown类型

表示变量的类型是未知的。常替代any。

Date类型
currentTime: Date;
interface类型

因为接口本身也是用来定义变量结构及包含的类型的, 所以在此一并整理。

interface Inter {a: string;
}let b: Inter = {a: '我是字符型'}

interface定义一个名称Inter对象,Inter对象里必定有一个变量a是字符串类型。

定义b时,就必须按照Inter接口的形式来定义。

即b是一个对象,b里必定有一个字符串型变量a 。

可索引接口类型
interface Inter {[x: number]: string;
}let a: Inter = ['hello', 'ts'];

意思是,创建一个接口Inter,定义变量a为Inter结构,

用数字型x去索引a,得到的是一个字符串。即:

a[0] = 'hello';a[1] = 'ts';
继承接口类型

一个接口可以继承另一个接口的属性和构造,

也可以同时继承多个接口的属性和构造。

interface InterA {a: number;
}interface InterB {b: string;
}interface InterC extends InterA, InterB {c: string;
}let d = <InterC>{};d.a = 1;d.b = 'ts';d.c = 'hello';
函数类型
function fn(a: string, b: number): boolean {// ...
}

意思是函数fn有字符串型变量a和数字型b两个参数,有返回值,

返回值是boolean类型。

如果没有返回值,就把boolean换成void。即:

function fn(a: string, b: number): void {// ...
}
泛型T

当我们需要在一个函数中的返回值类型和输入参数值类型保持相同时,

可以用泛型。

function identity<T>(arg: T): T {return arg;
}
交叉类型

A & B

这时变量会同时拥有多个类型的成员

联合类型

string | number

TS符号

类型断言

你明确知道某个变量的类型,并通过断言符号,告诉机器该变量的确切类型。

两种写法:

  1. (<类型>变量) 注:tsx里禁用这种写法
let a: any = 'a是字符串类型';let b: number = (<string>a).length;
  1. (变量 as 类型)
let a: any = 'a是字符串类型';let b: number = (a as string).length;
可选属性

变量?: 类型

interface Inter {a: string;b?: num;
}let c: Inter = {a: 'hello'};

首先定义了一个接口Inter,

然后定义变量c的结构为Inter结构,

那么变量c中必定还有一个字符串变量a,

可以有数字型变量b,也可以没有。

TS关键字

readonly只读

定义为只读的属性,不可被改变

interface Inter {readonly a: num;
}let b: Inter = { a: 2 };

此时,不能再去给b变量里的a赋值为其他值。

即 b.a = 3; // 报错

let c: number[] = [1, 3, 5, 4];let d: ReadonlyArray<number> = c;

此时的d,就是一个只读数组,不能对d做增删改的任何操作。

这篇关于2021.12.13 每天进步一点点: ts变量类型、符号、关键字的整理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942274

相关文章

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET