TypeScript快速入门 - 基本数据类型

TypeScript基本数据类型

1、布尔型

关键字:boolean

javascript 复制代码
let b: boolean = false;
console.log(b);
b = true;
console.log(b);

// false
// true

2、数字类型

关键字:number

javascript 复制代码
let num: number = 1;
console.log(num);

// 1

3、字符串类型

关键字:string

javascript 复制代码
let str: string = "str";
console.log(str);
let str1: string = "str1";
console.log(str1);

// str
// str1

4、数组类型

关键字:Array<数字类型> 、数据类型 [ ]

javascript 复制代码
let arr1: number[] = [1, 2, 3];
let arrStr: string[] = ['a', 'b'];

// 范型表示的数组
let arr2: Array<string> = ['a', 'b'];
console.log(arr1, arrStr, arr2);

// [1, 2, 3] ['a', 'b'] ['a','b']

5、元组类型

关键字:没有关键字,只有定义方式 [数据类型, 数据类型 ...数据类型 ]

javascript 复制代码
let tuple: [string, number, boolean] = ['a', 1, false];
console.log(tuple)

// ['a', 1, false]

6、枚举类型

关键字:enum

javascript 复制代码
enum Play {
    UP, DOWN, LEFT, RIGHT
}
enum Play1 {
    UP = 1, DOWN, LEFT, RIGHT
}

console.log(Play.UP, Play.DOWN);
// 0, 1

console.log(Play.UP, Play.DOWN);
// 1, 2

console.log(Play1.UP === 1);
// true

// 可以比较
console.log(Play1.UP === Play1.UP);
// true

// 错误实例
console.log(Play1.UP === Play.UP)
// 报错

7、任意数据类型

关键字:any

javascript 复制代码
let a: any = 1;
console.log(a);
a = 'a';
console.log(a);

// 1
// a

8、空返回类型

关键字:void

javascript 复制代码
function say(): void {
    console.log("我什么也不返回");
}

say();

// 我什么也不返回

9、null 和 undefined 类型

关键字:null 、 undefined

javascript 复制代码
let str: string = null;
console.log(str)

// null

// 不赋值 默认是undefined
let str2: string;
console.log(str2)

// undefined

10、nerver 和 Object

关键字:nerver 、 Object

javascript 复制代码
// 从来不使用的值 never
let a: never;
let b: string = "123";

// 会报错
a = 1;

console.log(b)

// 123

let c: Object = "123";
c = [1, 2, 3];
c = ["1", "2", "3"];
c = 4;
// Object和any类型有很相似的作用,Object是所有类型的父类,可以给他赋任意值
// 但Object类型的变量只是允许你给它赋任意值,但是却不能够在它上面调用任意的方法,即便它真的有这些方法

c.toFixed(); // Error: Property 'toFixed' doesn't exist on type 'Object'.
相关推荐
天下无贼!8 分钟前
2024年最新版Vue3学习笔记
前端·vue.js·笔记·学习·vue
Jiaberrr9 分钟前
JS实现树形结构数据中特定节点及其子节点显示属性设置的技巧(可用于树形节点过滤筛选)
前端·javascript·tree·树形·过滤筛选
赵啸林12 分钟前
npm发布插件超级简单版
前端·npm·node.js
我码玄黄44 分钟前
THREE.js:网页上的3D世界构建者
开发语言·javascript·3d
罔闻_spider1 小时前
爬虫----webpack
前端·爬虫·webpack
吱吱鼠叔1 小时前
MATLAB数据文件读写:1.格式化读写文件
前端·数据库·matlab
爱喝水的小鼠1 小时前
Vue3(一) Vite创建Vue3工程,选项式API与组合式API;setup的使用;Vue中的响应式ref,reactive
前端·javascript·vue.js
小晗同学1 小时前
Vue 实现高级穿梭框 Transfer 封装
javascript·vue.js·elementui
WeiShuai1 小时前
vue-cli3使用DllPlugin优化webpack打包性能
前端·javascript
Wandra1 小时前
很全但是超级易懂的border-radius讲解,让你快速回忆和上手
前端