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

相关文章

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python变量与数据类型全解析(最新整理)

《Python变量与数据类型全解析(最新整理)》文章介绍Python变量作为数据载体,命名需遵循字母数字下划线规则,不可数字开头,大小写敏感,避免关键字,本文给大家介绍Python变量与数据类型全解析... 目录1、变量变量命名规范python数据类型1、基本数据类型数值类型(Number):布尔类型(bo

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis