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

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

Python批量替换多个Word文档的多个关键字的方法

《Python批量替换多个Word文档的多个关键字的方法》有时,我们手头上有多个Excel或者Word文件,但是领导突然要求对某几个术语进行批量的修改,你是不是有要崩溃的感觉,所以本文给大家介绍了Py... 目录工具准备先梳理一下思路神奇代码来啦!代码详解激动人心的测试结语嘿,各位小伙伴们,大家好!有没有想

MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)

《MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)》本文给大家介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式,本文给大家介绍的非常详细,对大家的学习或... 目录完整 Hutool 写法版本对比优化为什么status变成Long?为什么 price 没事?怎

Java中的volatile关键字多方面解析

《Java中的volatile关键字多方面解析》volatile用于保证多线程变量可见性与禁止重排序,适用于状态标志、单例模式等场景,但不保证原子性,相较synchronized更轻量,但需谨慎使用以... 目录1. volatile的作用1.1 保证可见性1.2 禁止指令重排序2. volatile的使用