系统学习 TypeScript(三)——基础类型

简介: TypeScript 包含的基础类型总结起来有

7.png


前言


TypeScript 包含的基础类型总结起来有:


  • 布尔值
  • 数字
  • 字符串
  • 数组
  • 元组
  • 枚举
  • 任意值
  • 空值
  • Null 和 undefined
  • Never
  • Object


今天,我们就来详细了解一下各个类型所代表的含义及表示方法。


布尔值 → boolean


它只有两个值——true 和 false。


let isNew: boolean = true;


数字 → number


TypeScript 中的整形和浮点数类型都是 number,这点和  JavaScript 是一样的,比如:十进制、二进制、八进制和十六进制的类型都是 number。


let decAge: number = 22;
let hexAge: number = 0x0016;
let binaryAge: number = 0b10110;
let octalAge: number = 0o026;
// 以上变量使用 (number).toString(10) 转换为十进制都为 22


可使用 (number).toString(进制) 将数字转换为任意进制的类型。


字符串 → string


和 JavaScript 一样,字符串的值使用单引号或者双引号包裹:


let myName: string = "编程三昧";
let myHomepage: string = `example.com/${myName}`;


数组


TypeScript 中定义数组的方式有两种。


第一种是元素类型后面接上 [],表示由此类型元素组成的一个数组:


let arr: number[] = [1, 2, 3, 4];
// 如果在数组中加入其他元素会报错


第二种是使用数组泛型定义数组:


let arr1: any[] = [1, "2", 3, "4"];
// 这个数组中可以假如任意类型的元素


元组 Tuple


元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同。


let arr2:[number, string, number] = [1,"2",3];
// 若果写成 [1,2,3] 会报错


元素是严格规定了数组的长度和每个位置的元素类型,并且在赋值时需要严格对应,否则会报错。


枚举


enum类型是对JavaScript标准数据类型的一个补充。 像C#等其它语言一样,使用枚举类型可以为一组数值赋予友好的名字。


enum Color {Red, Green, Blue}
let c: Color = Color.Green;


默认情况下,从0开始为元素编号。 你也可以手动地指定成员的数值。 例如,我们将上面的例子改成从 1开始编号:


enum Color {Red = 1, Green, Blue}
let c: Color = Color.Green;


或者,全部都采用手动赋值:


enum Color {Red = 1, Green = 2, Blue = 4}
let c: Color = Color.Green;


枚举类型提供的一个便利是你可以由枚举的值得到它的名字。 例如,我们知道数值为2,但是不确定它映射到Color里的哪个名字,我们可以查找相应的名字:


enum Color {Red = 1, Green, Blue}
let colorName: string = Color[2];
console.log(colorName);  // 显示'Green'因为上面代码里它的值是2


任意值 any


代表任意类型的值。如果不希望类型检查器对这些值进行检查而是直接让它们通过编译阶段的检查。,那么就可以使用 any类型来标记这些变量:


let a: any = 12;
a = "12";


let list: any[] = [1, true, "free"];
list[1] = 100;


空值 void


当一个数据没有任何类型时,通常用 void 标记,多用于函数返回值。


function sayName(): void {
    console.log(`My name is 编程三昧。`);
}
let aNull: void = null;
let aNull1: void = undefined;


void 类型只能被赋值为 null 或者 undefined。


null 和 undefined


TypeScript 中也有 null 和 undefined 两种类型,它们只能各自对应 null 值和 undefined 值。


let theNull: null = null;
let theUndefined: undefined = undefined;


这两个类型基本上没啥大的用处。


null 和 undefined 是否可赋值给 number 类型的变量,取决于编译配置文件中的 “--strictNullChecks” 选项是否关闭,一般是建议打开这个选项的。


Never


never类型表示的是那些永不存在的值的类型。 例如, never类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型; 变量也可能是 never类型,当它们被永不为真的类型保护所约束时。


never类型是任何类型的子类型,也可以赋值给任何类型;然而,没有类型是never的子类型或可以赋值给never类型(除了never本身之外)。 即使 any也不可以赋值给never


下面是一些返回never类型的函数:


// 返回never的函数必须存在无法达到的终点
function error(message: string): never {
    throw new Error(message);
}
// 推断的返回值类型为never
function fail() {
    return error("Something failed");
}
// 返回never的函数必须存在无法达到的终点
function infiniteLoop(): never {
    while (true) {
    }
}


object


object 类型包含除了几种基本类型之外的所有类型。


let obj: object = [1,2,3];
let obj1: object = {
    name: "编程三昧"
};
let func: object = ()=>{
    console.log("编程三昧");
}


扩展


1、TypeScript 会根据你给变量的初始值判断默认类型。


let aNum = 12;
aNum = "number";
// Type 'string' is not assignable to type 'number'.


2、函数方法的参数和返回值都可以使用类型限制,保证传参和返回值的正确性。


function sum(a: number, b:number): number {
    return a + b;
}
sum(1, "3");
// Argument of type 'string' is not assignable to parameter of type 'number'.


总结


以上就是 TypeScript 中的基础数据类型介绍,总结起来就是:


  • 在变量(函数的括号)后面添加冒号,后面跟上期望的类型,即可限制类型的前后一致性;
  • 如果没有显式的添加类型限制,TypeScript 会根据初始值自动添加类型。


~ 本文完,感谢阅读!


学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!



相关文章
|
2天前
|
存储 人工智能 开发框架
Eliza:TypeScript 版开源 AI Agent 开发框架,快速搭建智能、个性的 Agents 系统
Eliza 是一个开源的多代理模拟框架,支持多平台连接、多模型集成,能够快速构建智能、高效的AI系统。
28 8
Eliza:TypeScript 版开源 AI Agent 开发框架,快速搭建智能、个性的 Agents 系统
|
2月前
|
设计模式 JavaScript 安全
TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等
本文深入探讨了TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等,旨在帮助开发者在保证代码质量的同时,实现高效的性能优化,提升用户体验和项目稳定性。
47 6
|
2月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
43 2
|
2月前
|
JavaScript 安全 前端开发
TypeScript类型声明:基础与进阶
通过本文的介绍,我们详细探讨了TypeScript的基础与进阶类型声明。从基本数据类型到复杂的泛型和高级类型,TypeScript提供了丰富的工具来确保代码的类型安全和可维护性。掌握这些类型声明能够帮助开发者编写更加健壮和高效的代码,提高开发效率和代码质量。希望本文能为您在使用TypeScript时提供实用的参考和指导。
42 2
|
2月前
|
JavaScript 开发者
在 Babel 插件中使用 TypeScript 类型
【10月更文挑战第23天】可以在 Babel 插件中更有效地使用 TypeScript 类型,提高插件的开发效率和质量,减少潜在的类型错误。同时,也有助于提升代码的可理解性和可维护性,使插件的功能更易于扩展和升级。
|
3月前
|
JavaScript 前端开发
TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第11天】TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
3月前
|
JavaScript 前端开发 安全
TypeScript【基础类型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第9天】TypeScript【基础类型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
2月前
|
JavaScript 前端开发 安全
TypeScript进阶:类型系统与高级类型的应用
【10月更文挑战第25天】TypeScript作为JavaScript的超集,其类型系统是其核心特性之一。本文通过代码示例介绍了TypeScript的基本数据类型、联合类型、交叉类型、泛型和条件类型等高级类型的应用。这些特性不仅提高了代码的可读性和可维护性,还帮助开发者构建更健壮的应用程序。
34 0
|
4月前
|
JavaScript
typeScript进阶(9)_type类型别名
本文介绍了TypeScript中类型别名的概念和用法。类型别名使用`type`关键字定义,可以为现有类型起一个新的名字,使代码更加清晰易懂。文章通过具体示例展示了如何定义类型别名以及如何在函数中使用类型别名。
52 1
typeScript进阶(9)_type类型别名
|
3月前
|
JavaScript 前端开发 安全
深入理解TypeScript:增强JavaScript的类型安全性
【10月更文挑战第8天】深入理解TypeScript:增强JavaScript的类型安全性
66 0