npm i -g typescript
E:\File\myNote\TypeScript>tsc hello.ts
npm install -g ts-node
写法一:先声明再赋值
let a: number;
a = '123';
var a;
a = '123';
写法二:声明的同时赋值
let a: number = 123;
写法三:声明的同时赋值并省略类型声明
let a = 123;
a = '123';
从写法三来看上面的写法好像都挺多余的,但是是为了应对js存在的问题:js中函数不会去考虑参数的类型和个数
function sum(a: number, b: number) {
return a + b;
}
console.log(sum(1, 2));
console.log(sum(1, '2'));;
第六行会报错了,但是仍然能够编译
类型
描述
number
任意数字
string
任意字符串
boolean
布尔值
字面量
限制变量的值就是该字面量的值
any
任意类型
unkown
类型安全的any
void
空值或undefined
never
不能是任何值
object
任意的js对象
array
任意的js数组
tuple
元素,TS新增数据类型,固定长度数组
enum
枚举,TS中新增类型
使用|来连接多个类型
let a : "123" | "456"
a = "789"
let b : number | boolean
b = "213"
均会报错
相当于对该变量关闭了TS的类型检测
let a : any;
a = 1;
a = '2';
上面的代码不会报错
在不进行类型声明的时候,变量会隐式声明为any类型
let a;
a = 1;
a = '2';
上面的代码也不会报错
unknown类型的变量在赋值的时候和any相同
any能够赋值给任意类型的变量,而unknown不能
let a;
a = 1;
a = '2';
let b : unknown;
b = 1;
b = '2';
let c : string;
c = a;
c = b;
上面的代码添加断言后就能通过编译了:
let a;
a = 1;
a = '2';
let b : unknown;
b = 1;
b = '2';
let c : string;
c = a;
c = b as string;
c = <string> b;
let fn = function (num: number | string): void {
console.log((num as string).length)
}
fn('12345')
fn(12345)
这里需要添加断言才不会报错,但是实际运行的时候仍然会报错(下面的fn传递的实际时number),所以类型断言仅仅只是欺骗了编译器,需要慎重使用
类型断言的使用技巧:向window上添加属性
(<any>window).abc = 123
不添加断言是不允许这样做的,因为window上并没有abc这个属性
function fun() : void {
}
同时拥有交叉的类型的所有属性
interface People {
name: string,
age: number
}
interface Man {
sex: number
}
const liu = function (man: People & Man) {
console.log(man)
}
liu({
name: 'liu',
age: 26,
sex: 1
})
手机扫一扫
移动阅读更方便
你可能感兴趣的文章