ts中的类型定义的详细使用教程

2023-11-29 16:12

本文主要是介绍ts中的类型定义的详细使用教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 原始数据类型(Primitive data types)
  • 特殊数据类型
  • 断言
    • 尖括号断言(Angle Bracket Syntax)
    • as 语法断言
    • 类型断言函数
  • 泛型
    • 数据容器
    • 数据类型转换
    • 工具函数
    • 接口定义
  • & 和 | 的用法
    • &
    • |
  • 后言

前言

hello world欢迎来到前端的新世界


😜当前文章系列专栏:Typescript
🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错误,感谢大家指出)🌹
💖感谢大家支持!您的观看就是作者创作的动力

原始数据类型(Primitive data types)

number: 表示数字,可以是整数或浮点数。

let zhuodou:number = 123

string: 表示字符串。

let zhuodou:string = "真帅"

boolean: 表示布尔值,即 true 或 false。

let zhuodou:boolean = false

null: 表示空值。在 TypeScript 中,null 是一个独立的类型,其它类型的子类型。

let zhuodou:null = null

undefined: 表示未定义的值。与 null 类似,undefined 也是一个独立的类型,其它类型的子类型。

let zhuodou:undefined = undefined 

symbol: 表示唯一标识符。

let zhuodou:symbol = undefined 

bigint: 表示任意精度的整数。

const num1: bigint = 123456789012345678901234567890n;
const num2: bigint = 987654321098765432109876543210n;const sum: bigint = num1 + num2;  // 可以进行数值运算,得到 1111111110111111111011111111100nconsole.log(sum.toString());  // 输出: "1111111110111111111011111111100"

特殊数据类型

unknown: 表示一种不确定的类型。它类似于 any 类型,但是更加安全,要求在使用之前进行类型检查或类型转换。

let userInput: unknown;
userInput = "Hello";
userInput = 10;if (typeof userInput === "string") {console.log(userInput.toUpperCase());
}

never: 表示永远不存在的值的类型。它通常用于表示总是会抛出异常或无法执行完整的函数,或是永远不会返回结果的函数。

function throwError(message: string): never {throw new Error(message);
}function infiniteLoop(): never {while (true) {}
}

void: 表示没有任何返回值的函数的类型。通常用于标记函数为无返回值。

typescript
function sayHello(name: string): void {console.log(`Hello, ${name}!`);
}

tuple: 表示一个固定长度的数组类型,其中每个位置的元素可能是不同的类型。例如:[string, number] 表示一个包含一个字符串和一个数字的数组。

typescript
let person: [string, number] = ["John", 25];
console.log(person[0]); // "John"
console.log(person[1]); // 25

enum: 表示一组具名的常数值。枚举类型常用于表示一组相关的常量,可以通过枚举的名字来引用其中的值。

enum Color {Red = "#FF0000",Green = "#00FF00",Blue = "#0000FF",
}let selectedColor: Color = Color.Red;
console.log(selectedColor); // #FF0000

never: 表示永远不存在的值的类型。它通常用于表示总是会抛出异常或无法执行完整的函数,或是永远不会返回结果的函数。

typescript
function throwError(message: string): never {throw new Error(message);
}function infiniteLoop(): never {while (true) {}
}

symbol: 表示唯一的、不可变的值。Symbol 类型可以用作对象属性的键或作为唯一标识符使用。

const key = Symbol("securityKey");let data = {[key]: "secure data",
};console.log(data[key]); // secure data

断言

尖括号断言(Angle Bracket Syntax)

let someValue: any = "hello";
let strLength: number = (<string>someValue).length;

as 语法断言

let someValue: any = "hello";
let strLength: number = (someValue as string).length;

类型断言函数

function assertString(value: any): asserts value is string {if (typeof value !== "string") {throw new Error("Value is not a string");}
}let someValue: unknown = "hello";
assertString(someValue);
let strLength: number = someValue.length; // 此处可以正常访问 length 属性

泛型

泛型(Generics)是 TypeScript 提供的一种特性,它能够让我们在定义函数、类、接口等数据类型时,定义一些可变的类型参数。这些类型参数可以用来表示不同类型之间的关联,增加代码的灵活性和复用性。

数据容器

在定义数组、链表、队列、堆栈等数据容器类型时,可以使用泛型来表示容器中元素的类型。

interface Container<T> {addItem(item: T): void;removeItem(item: T): void; 
}class Stack<T> implements Container<T> {private items: T[] = [];addItem(item: T) {this.items.push(item);}removeItem() {return this.items.pop();}
}const stack = new Stack<number>();
stack.addItem(1);
stack.addItem(2);
stack.removeItem(); // 2

数据类型转换

在进行数据类型转换时,可以使用泛型来表示源类型和目标类型。

function cast<T>(value: any): T {return value as T;
}const str = cast<string>(123); // "123"
const num = cast<number>("123"); // 123

工具函数

在编写工具函数时,可以使用泛型来处理具有不同类型的数据

function toArray<T>(value: T): T[] {return [value];
}const arr1 = toArray<number>(1); // [1]
const arr2 = toArray<string>("hello"); // ["hello"]

接口定义

在定义接口时,可以使用泛型来表示接口中的属性或方法的类型。

interface Response<T> {code: number;message: string;data: T;
}const res: Response<string> = {code: 200,message: "ok",data: "hello world"
}

& 和 | 的用法

&

它表示类型的交集。

type Person = {name: string;
}type Employee = {employeeId: number;
}type Manager = Person & Employee;const manager: Manager = {name: 'John Smith',employeeId: 1001,
};

|

它表示类型的并集。

type Status = 'active' | 'inactive' | 'pending';function setStatus(status: Status) {console.log('Status:', status);
}setStatus('active'); // 合法
setStatus('deleted'); // 非法,因为'deleted'不在Status类型的定义中

后言

创作不易,要是本文章对广大读者有那么一点点帮助 不妨三连支持一下,您的鼓励就是博主创作的动力

这篇关于ts中的类型定义的详细使用教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经