TS是JS的超集,所以JS基础类型都包含在内
安装ts:npm install typescript -g
查看版本号:tsc -v
普通编译ts : tsc 文件名.ts
运行tsc:node 文件名.js
还可以通过nodejs环境执行ts:
npm i @types/node --save-dev (node环境支持的依赖必装)
npm i ts-node --g
查看版本号:ts-node -v
运行:ts-node 文件.ts
ts的数据类型:
1.number类型
将number数字类型设置给num变量,那么此变量只能赋值数字类型,不能赋值其他数据类型,否则就会报错
let num: number = 123;
num=456,
num='123' //报错
// let num: number
// 不能将类型“string”分配给类型“number”。
2.boolean布尔类型
给flag配置布尔数据类型,那么后面赋的值,只能是true,false,或者是条件。因为会根据条件判断该条件是否成立,从而得出是true或者false。但是不能赋值其他的参数,否则就报错
let flag: boolean = true;
flag = false;
flag = 1>0;
flag='123' //报错:不能将类型“string”分配给类型“boolean”。
3.string字符串数据类型
将string数字类型设置给msg变量,那么此变量只能赋值字符串类型,不能赋值其他数据类型,否则就会报错
let msg: string = "hello world";
let name: string = "你好";
msg=123,//报错
// let msg: string
// 不能将类型“number”分配给类型“string”。
4.null和undefined数据类型
js中null和undefined是两个基本数据类型
在ts中 null和undefined他们是类型 也是值
var n = null;
var u = undefined;
n = null;
n = undefined;
5.Symbol数据类型
// @ts-ignore
let name1: symbol = Symbol("name");
// @ts-ignore
let name2: symbol = Symbol("name");
const obj = {
[name1]: "hello world",
[name2]: "你好世界",
}
6.Array数组数据类型
在数组中应该存放相同类型的数据,数组中定义什么类型的数组,那么此数组只能是该数据类型,不能赋值其他数据类型,否则就会报错
let arr: Array<string> = []; //第一种写法 react.jsx <div></div>
arr.push('你好')
arr.push(3,2,1) //报错类型“number[]”的参数不能赋给类型“string”的参数
let arr2: string[] = []; //第二种写法
arr2.push('123')
arr2.push(1,2,3) //报错:类型“number”的参数不能赋给类型“string”的参数
7.Object对象数据类型
对象方式要么直接不定义数据类型,要么是将里面有的变量的数据类型都给定义上
const obj1={ //这种可以读取name变量
name:"你好世界",
age:10
}
const obj2:{}={ //这种没有办法读取变量
name:"你好世界",
age:10
}
const obj3:object={//这种也没有办法读取变量
name:"你好世界",
age:10
}
const obj4:{name:string,age:number}={ //这种定义类型的可以读取变量
name:'你好世界',
age:18
}
console.log(obj1.name);
console.log(obj2.name);
console.log(obj3.name);
console.log(obj4.name);
8.any数据类型
变量定义的any数据类型,那么此变量可以定义任何类型的数据,但是不推荐也不经常用,一般都是用在声明变量接收将要获取到的数据,此时以防报错先定义any,当数据获取到后指定什么数据类型了再给改为其他数据类型
//msg这个数据的数据类型可以是任何的数据(和原来的js就完全一样了)
let msg: any = "1234";
msg = 123;
msg = true;
msg = [];
msg = null;
9.unknown数据类型
unknown类型 只能赋值给any和unknown类型的变量;
any类型 可以赋值给任意类型的变量
10.void数据类型
当函数中有确定数据类型的返回值的话不可以使用void数据类型,否则就报错。如果此函数中没有返回值的话可以使用void数据类型
//void 当前方法没有返回值
function fn(num:number, num2:number): number{
return num+num2
}
function fn2(num:number, num2:number): void{
console.log(num+num2)
//在此函数如果没有return的话,可以使用void
return num+num2 //报错 不能将类型“number”分配给类型“void”。
}
let run1 = fn(1,2)
let run = fn2(1,2)
11.never数据类型
never表示永远都不会发生值的类型
列:
function fn(): never{
throw new Error("手动错误")
}
function fn1(): never{
while (true){
console.log(1)
}
}
function checkType(msg: string | number | boolean){
let str = "";
switch (typeof msg){
case "string":
str = "string"
break;
case "number":
str = "number"
break;
case "boolean":
str='boolean'
let check: never = msg;//报错 不能将类型“boolean”分配给类型“never”。
break;
default:
let check: never = msg; //所以写到这里,当上面的类型判断完后,再没有可判断的里面可以定义never数据类型
}
return msg+","+str
}
checkType("123")
checkType(123)
checkType(true)
12.tuple元组数据类型
我们已经知道数组中的数据类型应该统一,如果不统一,那么应该尝试使用对象来代替,但是使用元组,可以做到不统一的数据类型数组
tuple元组表示多种元素的组合,元组是必须要赋值的,元组的情况就是当我们返回值要放在数组里面,并且数据类型又不一样而且又有初始值的时候,这个时候就可以尝试着元组的数据类型,这样写成这个元组的数据类型别人分别用这个东西的时候,它可能使用到es6的解构赋值进行了一个接收,接受完了之后,该方法就会当作方法使用,该是其他的数据类型的时候就当作其他就属性用就可以了,里面可以写string,Array,或者其他类型
写法就是在 [ ] 里面定义每一个可能用到的数据类型,并且一定要赋值
//元组 必须要赋值
let arr: [string, number, boolean] = ["name", 18, true]
console.log( arr[0].length); //4
arr[1].length // 类型“number”上不存在属性“length”
13.枚举类型
枚举就是将一组可能出现的值, 一个一个列举出来, 定义在一个类型中,这个类型就是枚举类型。
枚举类型放常量 字符串 数字 (全大写)
enum Direction {
LEFT = "LEFT",
RIGHT = "11",
TOP = "1111",
BOTTOM = 100
}
enum Url {
DEV_URL = "www.baidu.com",
PROD_URL = "www.baidu.com1",
TEST_URL = "www.baidu.com2"
}
let a:Direction = Direction.LEFT;
function move(direction: Direction){
console.log(direction)
switch (direction){
case Direction.LEFT:
console.log("向左移动")
break;
case Direction.RIGHT:
console.log("向右移动")
break;
case Direction.TOP:
console.log("向上移动")
break;
case Direction.BOTTOM:
console.log("向下移动")
break;
default:
let err:never = direction
}
}
move(Direction.LEFT)
move(Direction.RIGHT)
move(Direction.TOP)
move(Direction.BOTTOM)