TS的类型声明

目录

1.TS把JS变成了静态类型的语言,可以给变量指定类型

 2.JS中的函数是不考虑参数的类型和个数的,但是TS会考虑函数的参数类型和个数,且要规定返回值类型。

3.常见的TS类型

1.可以直接使用字面量进行类型声明 

字面量声明的应用:可以使用 | 来连接多个类型(联合类型)

 & 表示同时满足

2.any类型(不建议使用)

表示的是任意类型,一个变量设置类型为any后相对于对该变量关闭了TS的类型检测。

使用TS时,不建议使用any类型

​编辑 

3.unknown类型

4.void   虽然说void 用来表示空,以函数为例,就表示没有返回值的函数。但是会默认返回一个 undefined

5.never 也表示空,但真的就是啥都不返回

6.object 对象类型(不推荐写)   推荐这样写:let a :{name:string}; 要指定对象里面的属性

对象的可选属性(重要)

7.array  实际开发中希望数组里面存的都是同一类型的数据

8.tuple 元组,就是固定长度的数组

9.enum 枚举 

4.类型的别名

5.类型定义的注意点


1.TS把JS变成了静态类型的语言,可以给变量指定类型

TS的类型声明_第1张图片

 注意点1:这里就算报错,编译时也会生成一个对应的js文件,因为给a赋值字符串是符合js语法的,是可以编译的,这样可以让初学ts的更容易上手。

TS的类型声明_第2张图片

TS的类型声明_第3张图片注意点2编译后产生的js文件中会出现 var 这些,是因为TS可以把代码编译成任意版本的JS代码 

TS的类型声明_第4张图片

注意点3:变量先声明,再赋值  和 声明后直接赋值的区别

变量先声明,再赋值,必须要写类型。

TS的类型声明_第5张图片

先声明直接赋值可以不用写类型,但是后面再给变量赋值必须是同一类型。 

TS的类型声明_第6张图片

 2.JS中的函数是不考虑参数的类型和个数的,但是TS会考虑函数的参数类型和个数,且要规定返回值类型。

 TS的类型声明_第7张图片

 传入的参数类型和个数和函数接受的参数类型和个数一一对应,且返回值类型也要规定。

如果不写返回值类型,会自动检测 return 返回得结果:

TS的类型声明_第8张图片

如果函数没有写返回值:此时函数返回值类型为void (默认返回值undefined)

TS的类型声明_第9张图片

 TS的类型声明_第10张图片

所以:如果函数没有返回值,就可以 写 void :用来表示空,表示没有返回值

function fn():void{
    console.log(11111);
}

3.常见的TS类型

TS的类型声明_第11张图片

1.可以直接使用字面量进行类型声明 

TS的类型声明_第12张图片

字面量声明的应用:可以使用 | 来连接多个类型(联合类型)

//可以直接使用字面量进行类型声明
let a: 10;    //这样的含义就是 a 只能为10 不能为其它值
a = 10;

//可以使用 | 来连接多个类型(联合类型)
let b: 'male' | 'female';  //值只在几个范围之内
b = 'male';
b = 'female';

let c:boolean | string;    //值之在几个类型之类
c = true;
c = 'hello';

 & 表示同时满足

let n:{name:string} & {age:number};

n = {name:'天空',age:22}

2.any类型(不建议使用)

表示的是任意类型,一个变量设置类型为any后相对于对该变量关闭了TS的类型检测。

使用TS时,不建议使用any类型

TS的类型声明_第13张图片

声明变量如果不指定类型,则TS解析器会自动判断变量的类型为any(隐私的any) 

TS的类型声明_第14张图片 注意点:any类型的变量值可以赋值给任意变量 ,且不会报错,这也是不建议用any的原因。

TS的类型声明_第15张图片

3.unknown类型

与any类型类似,区别在于any类型可以赋值给任意变量 ,且不会报错,但是unknown类型赋值给非unknown类型变量时会报错。

TS的类型声明_第16张图片

 unknown 实际上就是一个类型安全的any

unknown 类型的变量,不能直接赋值给其它变量,如果需要赋值给其它类型变量,可以像下面这样操作:

操作1:

TS的类型声明_第17张图片

 操作2:类型断言:可以用来告诉解析器变量的实际类型

语法:

        变量   as  类型

        或者:

        <类型>变量

TS的类型声明_第18张图片

 总结:遇到一个类型不确定的变量时,能用 unknown 时,尽量用 unknown,最好不用 any。

4.void   虽然说void 用来表示空,以函数为例,就表示没有返回值的函数。但是会默认返回一个 undefined

 虽然说void 用来表示空,以函数为例,就表示没有返回值的函数。但是会默认返回一个 undefined

function fn():void{
    console.log(11111);
}

5.never 也表示空,但真的就是啥都不返回

 never 也表示空,但真的就是啥都不返回,undefined也不返回。也就是报错的时候,函数才啥都不返回

//never :表示永远不会返回结果
function fn2():never{
    throw new Error('报错了');
}

6.object 对象类型(不推荐写)   推荐这样写:let a :{name:string}; 要指定对象里面的属性

let a :object;
a = {};
a = function(){};
a = [1,2,34];

因为js中,一切皆对象,所以object开发时运用的比较少。

所以一般指定一个对象的话,要指定对象里面包含什么属性:

语法:

        { } 用来指定对象中可以包含哪些属性

        语法:{属性名:属性值类型,属性名:属性值类型}

let m :{name:string};
m = {name:'花花'};

对象的可选属性(重要)

1.限制某一个属性 :如下 age? 只能是age属性选与不选

在属性名后面加上一个? 表示属性是可选的。

 注意点:如果不确定该属性是否有,可以这样:

 这表示:如果后面需要用到该属性就写,不需要用,不写也不会报错

TS的类型声明_第19张图片

2.任意属性名都可以是选与不选  [propName:string]:any   定义对象的类型属性

//表示任意类型的属性 [propName:string]:any}
let m :{name:string,[propName:string]:any}; //表示对象里面有一个name属性,其它属性有啥不用管

m = {name:'花花',bir:'2000-07'};

m = {name:'天空',age:22}

 3.定义函数的类型属性

设置函数结构的类型声明:

        语法:(形参:类型,形参:类型 。。。)=>返回值

let q:(a:number,b:number)=>number; //表示函数有2个参数,参数类型都是number,返回值是number类型

q = function(n1:number,n2:number):number{
    return n1 + n1;
}

7.array  实际开发中希望数组里面存的都是同一类型的数据

语法:

        1. let  f :number[ ] = [ ];    //表示一个数组,其中数据都是number类型的

        2. let  f :Array = [ ];  //表示一个数组,其中数据都是number类型的

        eg:如果想数组里面啥类型数据都可以取

                let f :Array;

let arr:Array = [1,'hello',true];

TS的类型声明_第20张图片

分析:其中: let arr:string[]; 表示:arr是一个数组,且里面存的数据,都是字符串类型的。

8.tuple 元组,就是固定长度的数组

语法:

        [类型,类型,类型]

let h:[string,number];
h = ['hell0',1233];

9.enum 枚举 

 把所有的可能情况一一列出来。

结果在多个值之间进行选择的时候适合用枚举。

//定义一个枚举类
enum Gender{         //性别  
    Male = 0,
    Female = 1
}
//定义一个对象,它的gender属性值是一个枚举
let i:{name:string,gender:Gender}
i = {
    name:'天空',
    gender:Gender.Male
}
console.log(i.gender === Gender.Male);//将ts文件编译后引入html文件中,在浏览器中打开
//结果为true

4.类型的别名

type myType = string;
//给类型取一个别名
type myType = string;
let m:myType = 'hell0';
//作用:如果一个数据的类型太长,可以用别名代替
type myType1 = 1|2|3|4|5;
let n:1|2|3|4|5 = 5;
let q:myType1 = 5;   //这种就显得很简洁

5.类型定义的注意点

类型不一定非得是 number,string,等这些关键字,可以是其它,但是要对应得上 

let n:1|2|3|4|5 = 5;
let n:'hello' = 'hello';

TS的类型声明_第21张图片

你可能感兴趣的:(Vue的学习,前端,html)