TS中的数据类型

news2024/12/25 23:46:58

一、number类型

let c: number;
c = 10;
c = "hello";  // 不能复制string类型

二、string类型

let d: string;
d = "hello";
d = 10;  // 不能复制number类型

三、boolean类型

let e: boolean = true;
e = false;
e = 10; // 不能赋值true和false以外的值

 四、字面量类型

字面量类型的主要作用是限制字面量类型的值

let f: 10;
f = 10;
f = 11;  // 报错:不能赋值10以外的值
f = "10"; // 报错:不能赋值10以外的值

上面这种方法你可以认为将变量f定义为了一个常量,其值只能为10。

更多的时候我们会搭配 | 或运算来使用:

let g: "apple" | "banana";
g = "apple";
g = "banana";
g = "wotermelon";  // 报错:不能赋值"apple"和"banana"以外的值

字面量除了值,还可以使用数据类型搭配 | 或运算使用:

let h: boolean | string;
h = true;
h = "hello";
h = 10;  // 报错:不能赋值boolean和string以外数据类型的值

五、any类型

any表示任意的数据类型,一个变量设置了any的数据类型,相当于对该变量关闭了变量数据类型检测。

let i: any;
i = 10;
i = "hello";
i = true;

但是我们不建议使用any数据类型。

如果我们声明变量时不指定其数据类型,TS解析器就会自动判断其为any数据类型;

 注意:any数据类型的变量可以赋值给其他数据类型的变量,这会导致变量污染

let s: string;
s = i;

 六、unknown类型

 unknown表示未知数据类型的值,也可以是任意数据类型

let j: unknown;
j = 10;
j = "hello";
j = true;

但是unknown数据类型和any数据类型最大的区别是unknown数据类型的值不能直接赋值给其他数据类型的变量:

let s: string;
s = j;  // 报错:不能将类型“unknown”分配给类型“string”

但是我们能通过一下两种方式完成unknown数据类型的对其他数据类型的变量的赋值:

(一)判断unknown数据类型变量的当前数据类型 

let s: string;
if (typeof j === "string") {
    s = j;
}

(二)类型断言

相当于是告诉TS编译器这个变量的实际数据类型

类型断言有两种写法:

变量 as 数据类型

s = j as string;

<数据类型> 变量

s = <string>j;

 七、void类型

void表示空值,多用于函数的返回值类型中,当我们没有设置返回值时,TS编译器会自动判断其返回值为void。

当然TS也能够自动判断其返回值的类型

 

当我们设置了函数的返回值类型为void后,能够返回空和undefined,返回其他数据类型会报错

function fn() : void{
    return;
}
function fn() : void{
    return undefined;
}
function fn() : void{
    return "";  // 报错:不能将类型“string”分配给类型“void”
}

 八、never类型

never在函数返回值类型中表示永远不会有返回结果

我们知道,在JavaScript中函数不设置返回值但是会默认返回undefined,所以即使在返回值为never数据类型的函数中什么都不写也会进行报错。

因此返回值为never用于永远都不会有返回值的场景,也就是报错。

function fn1(): never{
    throw new Error("报错了!");
}

 九、object类型

object是对象类型,但是JS中万物皆对象,因此我们定义一个变量为对象数据类型的意义并不大。

let k: object;
k = {};  // k为一个空对象
k = function fn() { };  // k为一个函数对象

我们在TS中对对象的使用更偏向于以下用法

{ 属性名 :属性值 , 属性名 : 属性值 }

let l: { name: string };
l = { name: "孙悟空" };

(一)任意类型的属性

当赋值的对象中的属性与声明对象的属性匹配时就会报错 

 

可以选择加上就行

let l: { name: string; age: number };
l = { name: "孙悟空", age: 18 };

也可以使用任意类型的属性:

{ [ propName : string ] : any } 

let l: { name: string; [propName: string]: any };
l = { name: "孙悟空", age: 18, gender: "男" };

(二)可选属性 

当赋值的属性少了时也会进行报错

let l: { name: string, age: number };
l = { name: "孙悟空"};  // 报错:类型 "{ name: string; }" 中缺少属性 "age"

在age属性名后加上一个?表示该属性为可选项

{ 属性名? : 属性值 } 

let l: { name: string, age?: number };
l = { name: "孙悟空"};

(三)函数结构的对象声明

( 形参1 : 数据类型 , 形参2 : 数据类型 ... )=>返回值数据类型

let m: (a: number, b: number) => number;
m = function (n1, n2) {
  return n1 + n2;
};

注意:这里的形参个数和数据类型,以及函数的返回值类型都需要和声明时一致,默认为声明时的配置。

十、array类型

(一)第一种数组声明方式

数据类型[]

let n : string[];
n = ["a", "b", "c"];

 (二)第二种数组声明方式

Array<数据类型>

let n : Array<string>;
n = ["a", "b", "c"];

 同样的,在指定数据类型的数组中加入其他数据类型的元素也会报错。

十一、tuple类型

tuple是元组数据类型,也就是长度固定的数组

[数据类型 , 数据类型 , 数据类型...]

let o: [string, string];
o = ["abc", "hello"];

其赋值的数组长度和类型都必须一一对应

let o: [string, string];
o = ["abc"];  // 报错:不能将类型“[string]”分配给类型“[string, string]”。

十二、enum类型

enum是枚举类型,适用于有限选择的情况

let p: { name: string, gender: string };
p = { name: "孙悟空", gender: "男" };
console.log(p.gender === "男");

我们在上面的代码中的gender使用“男”来表示,但是性别只有“男”和“女”这两种,用0和1来表示能够更方便,这时候就可以使用enum数据类型。

enum 变量名 { 属性名 = 0, 属性名 = 1, ...}

enum Gender{
  Male = 0,
  Female = 1
}
let p: { name: string, gender: Gender };
p = { name: "孙悟空", gender: Gender.Male };
console.log(p.gender === Gender.Male);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1024572.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Cypress安装与使用教程(1)—— 软测大玩家

&#x1f60f;作者简介&#xff1a;博主是一位测试管理者&#xff0c;同时也是一名对外企业兼职讲师。 &#x1f4e1;主页地址&#xff1a;【Austin_zhai】 &#x1f646;目的与景愿&#xff1a;旨在于能帮助更多的测试行业人员提升软硬技能&#xff0c;分享行业相关最新信息。…

半导体划片机工艺应用

半导体划片工艺是半导体制造过程中的重要步骤之一&#xff0c;主要用于将大尺寸的晶圆切割成小片&#xff0c;以便进行后续的制造和封装过程。以下是一些半导体划片工艺的应用&#xff1a; 晶圆划片&#xff1a;在半导体制造过程中&#xff0c;需要将大尺寸的晶圆切割成小片&am…

【数据库系统概论】数据库系统外部的体系结构

单用户结构主从式结构分布式结构客户机&#xff0f;服务器结构&#xff08;C/S结构&#xff09;浏览器 / 服务器结构&#xff08;B/S结构&#xff09;感谢 &#x1f496; 上一篇文章 数据库系统的三级模式和二级映射介绍的是数据库系统内部的体系结构&#xff0c;是从应用开发…

计算机网络知识补充(1)

计算机网络:是一个将分散的&#xff0c;具有独立功能的计算机系统&#xff0c;通过通信设备和线路进行连接起来&#xff0c;由功能完善的软件实现资源共享和信息共享的系统&#xff0c;计算机网络是互连的&#xff0c;自治的计算机集合 互连:通过通信链路来进行互联互通 自治:没…

云安全威胁和责任

云计算的共享特性和按需定制本质除了给企业带来效率上提升&#xff0c;也引入了新的安全威胁&#xff0c;有可能使企业得不偿失。 之前云安全联盟(CSA)的报告便指出&#xff0c;云服务天生就能使用户绕过公司范围内的安全策略&#xff0c;建立起自己的影子IT项目服务账户。 新的…

全面感知,智能预警!燃气感知云,守护城市“烟火气”

燃气安全如何保障&#xff1f;燃气企业如何精准运营&#xff1f;天翼物联基于感知云平台创新能力&#xff0c;提供燃气感知云服务&#xff0c;包括泛协议接入、感知云燃气平台、燃气感知数据治理、决策处置大屏四大服务&#xff0c;构建燃气行业感知神经系统新型数字化底座&…

Interceptor的使用场景:拦截请求中的租户信息,注入到租户上下文中

业务场景 在SaaS环境中&#xff0c;租户是最重要的隔离业务数据的属性了&#xff0c;在自己的项目体系环境中&#xff0c;租户id能保证有值。但有个特殊场景&#xff0c;某些特殊权限的账号需要修改指定租户的内容&#xff0c;也即前端会携带租户信息过来&#xff0c;并且内部涉…

【力扣-每日一题】2560. 打家劫舍 IV

class Solution { public:bool check(vector<int> &nums,int max_num,int k){//只需要计算可以偷的房间。在满足最大值为max_num下时&#xff0c;能偷的最多的房间&#xff0c;与k值比较//如果大于K&#xff0c;说明max_num还可以缩小//如果小于看&#xff0c;说明ma…

深入解析容器与虚拟化:技术、对比与生态

深入解析容器与虚拟化&#xff1a;技术、对比与生态 文章目录 深入解析容器与虚拟化&#xff1a;技术、对比与生态容器和虚拟化的基本概念和原理容器的定义和特点虚拟化的定义和特点 容器使用场景容器和虚拟机的对比虚拟化技术的四个特点容器实现虚拟化的原理常见容器引擎和容器…

【Ubuntu配置ssh和sftp与windows的xshell连接】

【Ubuntu配置ssh和sftp与windows的xshell连接】 一、Ubuntu配置ssh1、查看是否已经安装2、安装openssh server3、修改端口 修改Port后的参数4、重启ssh5、查看状态6、查看端口 二、windows连接 一、Ubuntu配置ssh 1、查看是否已经安装 dpkg -l | grep ssh2、安装openssh serv…

IntelliJ IDEA学习总结(3)—— IntelliJ IDEA 常用快捷键(带动图演示)

一、构建/编译 Ctrl + F9:构建项目 该快捷键,等同于菜单【Build】—>【Build Project】 执行该命令后,IntelliJ IDEA 会编译项目中所有类,并将编译结果输出到out目录中。IntelliJ IDEA 支持增量构建,会在上次构建的基础上,仅编译修改的类。 Ctrl + Shift + F9:重新编…

程序员戴什么样的眼睛比较好

眼镜https://baijiahao.baidu.com/s?id1770288495355869186&wfrspider&forpc

【JDK 8-集合框架】5.3 limit 和 sorted 函数

一、sorted 函数 二、limit 函数 三、实战 执行结果&#xff1a; 一、sorted 函数 对流进行自然排序&#xff0c;其中的元素必须实现Comparable 接口 sorted(Comparator<? super T>comparator) 用来自定义升降序 二、limit 函数 获取指定数量的元素 (limit(long …

《机器学习基石前四章复习》

【引言】 训练样本D和最终测试h的样本都是来自同一个数据分布&#xff0c;这是机器能够 学习的前提。另外&#xff0c;训练样本D应该足够大&#xff0c;且hypothesis set的个数是有限的&#xff0c;这样 根据霍夫丁不等式&#xff0c;才不会出现Bad Data&#xff0c;保证Ein≈…

2023年9月19日

2> 完成文本编辑器的保存工作 头文件 #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QFontDialog> #include <QMainWindow> #include <QFont> #include <QMessageBox> #include <QDebug> #include <QColorDialog> #include &l…

Flask框架-1-[群聊]: flask-socketio实现websocket的功能

一、项目结构 flask_websocket |---static |---js |---jquery-3.7.0.min.js |---socket.io_4.3.1.js |---templates |---home |---group_chat.html |---index.html |---app.py 1.1、python环境 python3.9.0 1.2、依赖包 Flask2.1.0 eventlet0.33.3 Flask-SocketIO5.3.4 1.…

温习JAVA

1.时间 作业题&#xff1a; 1.子串在字符串中出现的次数 import java.util.Scanner;/*** 分别在控制台输⼊字符串和⼦字符* 串&#xff0c;并计算字符串中⼦字符串出现的* 次数。indexOf(subs,n)*/ public class H5 {public static void main(String[] args) {Scanner scnew …

linux搭建单机ES,集成ik分词器,文本抽取,Kibana可视化平台

Elasticsearch单机&#xff08;Linux&#xff09; 准备工作 第一项&#xff1a; 创建运行Elasticsearch和Kibana专用的普通用户&#xff0c;因为 elasticsearch 和 kibana 不允许使用 root用户启动&#xff0c;所以需要创建新用户启动。 linux用root权限创建一个用户赋权即可…

BootStrap中的布局

1.BootStrap中的布局 2.BootStrap 中的媒体查询 // Extra small devices (portrait phones, less than 576px) media (max-width: 575px) { ... }// Small devices (landscape phones, 576px and up) media (min-width: 576px) and (max-width: 767px) { ... }// Medium dev…

38 | 统一测试数据平台

测试数据准备的 2.0 时代 在Java中可以利用Builder Pattern&#xff0c;创建数据时如对其中的某个或某几个参数有特定要求的话&#xff0c;可以通过“.withParameter()”的方式指定&#xff0c;而没有指定的参数将自动采用默认值。 UserBuilder.withCountry(“US”).withBuild…