TypeScript 第三天,TypeScript中的类型(二)

这是之前的内容,我们自行回顾一下:# TypeScript 第二天,TypeScript中的类型(一)

object

object 表示一个js对象,对象类型可以使用以下方法定义:

TypeScript 复制代码
let a: object;
a = {};
a = function(){};

我们也可以限定对象中有哪些参数,如下所示:

TypeScript 复制代码
let b:{name:string,age?:number}; 
b = {name:'孙悟空',age:18}

其中,{}来指定对象中可以包含哪些属性,语法为:{属性名:属性值},如果在属性后名后面加上?表示属性是可选的。 当然如果我们想定义很多个类型都是相同的限制条件怎么写呢?比如除了姓名性别还有身高,爱好,电话......这里面其他的字段都是字符串,如何写呢?请看下面例子:

TypeScript 复制代码
let c:{name:string,[propName:string]:any}
c = {name:"猪八戒",age:18,gender:'男'};

上面代码中,[propName:string]:any表示任意类型的属性,那么我们方法的类型该如何定义呢?代码如下:

TypeScript 复制代码
/**
 * 设置函数结构的类型声明
 * 语法:(形参:类型,形参:类型)=> 返回值
 */
let d:(a:number,b:number)=>number;
d = function(n1,n2){
  return n1+n2;
}

和上面一样我们在定义一个方法之前使用上面方法定义就可以了,语法就是:(形参:类型,形参:类型)=> 返回值.

array

array数组,我们如何来限定数组里面的数据类型呢?我们看下面例子:

TypeScript 复制代码
let e:string[];
let e = ['a','b','c'];

我们可以定义一个数组里面都是字符串,代码如上。当然我们也可以用其他方式定义,接下我们看:

TypeScript 复制代码
let g:number[];
g = [1,2,3];

number[]表示数值数组,说明我们也可以使用这种方式限定数组中内容的类型,当然我们还有另外一种写法,如下:

TypeScript 复制代码
let g:Array<number>;

上面这种写法也是我们比较常见的一种写法。

tuple

tuple表示我们的元组,也就是说固定长度的数组,我们看下面代码:

TypeScript 复制代码
let n:[string,string];
n = ['hello','123'];

像上面一样我们就可以限定每个元组的存储类型了,更加方便使用。

enum

enum是我们的枚举类型,枚举说的就是固定的内容,和MySQL一样有一个字段类型也是enum枚举的意思,大部分用来存储固定内容的数组,而且里面的内容都是不重复的。TypeScript估计借用了这种思想,我们看一下如何使用:

TypeScript 复制代码
enum Gender{
    Male = 0,
    Female = 1
}
let i:{name:string,gender:Gender};
i = {
    name:'孙悟空',
    gender:Gender.Male
}
console.log(i.gender === Gender.Male);

还有一个&与和|或需要再注意一下,我们来看一个例子:

TypeScript 复制代码
// & 表示同时
let j:{name:string} & {age:number};
j = {
    name:'孙悟空',
    age:18
};

上面的与和或和我们Javascript中的与和或用法一样,原理自己理解很简单。

类型的别名

ini 复制代码
type myType = 1|2|3|4|5;
let k:myType;
k = 1;

好了今天就介绍到这里,明天继续类型的别名。感谢大家观看。

相关推荐
fruge3 小时前
TypeScript 基础类型与接口详解
javascript·ubuntu·typescript
海鸥两三21 小时前
Uni-App(Vue3 + TypeScript)项目结构详解 ------ 以 Lighting-UniApp 为例,提供源代码
vue.js·typescript·uni-app·1024程序员节
菜鸟una2 天前
【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)
前端·vue.js·微信小程序·小程序·typescript·taro·1024程序员节
前端初见2 天前
快速上手TypeScript,TS速通
javascript·ubuntu·typescript
郑板桥302 天前
TypeScript:npm的types、typings、@type的区别
javascript·typescript·npm
Java陈序员2 天前
免费高颜值!一款跨平台桌面端视频资源播放器!
vue.js·typescript·electron
菜鸟una3 天前
【瀑布流大全】分析原理及实现方式(微信小程序和网页都适用)
前端·css·vue.js·微信小程序·小程序·typescript
还是大剑师兰特3 天前
TypeScript 面试题及详细答案 100题 (71-80)-- 模块与命名空间
前端·javascript·typescript
一点七加一3 天前
Harmony鸿蒙开发0基础入门到精通Day01--JavaScript篇
开发语言·javascript·华为·typescript·ecmascript·harmonyos
还是大剑师兰特3 天前
TypeScript 面试题及详细答案 100题 (61-70)-- 泛型(Generics)
typescript·大剑师·typescript教程·typescript面试题