typescript 数据类型整理

本文介绍了TypeScript中的多种基础数据类型,包括布尔值、数字、字符串、数组、元组、枚举等,说明了各类型的特点和使用方式,如数字支持多种进制,字符串可用模板字符串等。还提及了Any、void等特殊类型,以及类型断言,它类似强制转换,仅在编译阶段起作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

布尔值

boolean

let isDone: boolean = false;

数字

number 支持十进制、十六进制、二进制、八进制

let decLiteral: number = 6;
let hexLiteral: number = 0xf00d;
let binaryLiteral: number = 0b1010;
let octalLiteral: number = 0o744;

字符串

string

和其他语言相似

可以使用模板字符串、用反引号包围`` 可以使用${} 嵌入表达式

let name: string = `Gene`;
let age: number = 37;
let sentence: string = `Hello, my name is ${ name }.

I'll be ${ age + 1 } years old next month.`;

数组

定义有两种方法,

let list: number[] = [1, 2, 3];`
let list: Array<number> = [1, 2, 3];

元组

Tuple

元组类型允许表示元素的数量和类型的数组,各元素不必相同

// Declare a tuple type
let x: [string, number];
// Initialize it
x = ['hello', 10]; // OK
// Initialize it incorrectly
x = [10, 'hello']; // Error

可以使用索引得到之,当数组越界后使用联合类型替换

x[3] = 'world'; // OK, 字符串可以赋值给(string | number)类型
console.log(x[5].toString()); // OK, 'string' 和 'number' 都有 toString
x[6] = true; // Error, 布尔不是(string | number)类型

枚举

enum

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

默认从0开始但是可以手动制定成员的数值

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


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

Any

不确定类型

void

无类型

Null Undefined

可以看作任何类型的子类型

可以复值给其他类型

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表示非原始类型,也就是除number,string,boolean,symbol,null或undefined之外的类型。

类型断言

像是其他语言的强制转换

但是只有在编译阶段起作用,

let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length;
let someValue: any = "this is a string";
let strLength: number = (someValue as string).length;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值