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

相关文章

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

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

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

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

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

Perl 特殊变量详解

《Perl特殊变量详解》Perl语言中包含了许多特殊变量,这些变量在Perl程序的执行过程中扮演着重要的角色,:本文主要介绍Perl特殊变量,需要的朋友可以参考下... perl 特殊变量Perl 语言中包含了许多特殊变量,这些变量在 Perl 程序的执行过程中扮演着重要的角色。特殊变量通常用于存储程序的

C# dynamic类型使用详解

《C#dynamic类型使用详解》C#中的dynamic类型允许在运行时确定对象的类型和成员,跳过编译时类型检查,适用于处理未知类型的对象或与动态语言互操作,dynamic支持动态成员解析、添加和删... 目录简介dynamic 的定义dynamic 的使用动态类型赋值访问成员动态方法调用dynamic 的

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]