学习ts(二)数据类型(接口和对象类型、数组类型)

interface

重名会重合到一起

如果两个interface名称相同,会把两个合到一起

重复定义同一个需要类型相同

不能多或者减少属性

设置任意key

当定义接口返回数据时,我们不确定接口会返回多少,知道所需要的固定属性,其余属性可以设置为[propName: string]
需要注意的是,一旦定义了任意属性,那么确定属性和可选属性的类型都必须是它的类型的子集

可选

js 复制代码
interface Modal {
    name: string
    age: number
    b?:number
}
let modal: Modal = {
    name: '123',
    age: 12,
}

只读

常用于id和函数,不想被修改

继承

相当于再次合并两个接口

函数定义

相当于定义了一个参数为name,返回值为数字数组类型的函数

js 复制代码
interface Fn {
    (name: string): number[]
}

let fn1:Fn = (name:string)=>{
    return [1,2,3]
}

数组类型

采用普通方式定义和泛型方式定义基本数组类型

定义对象数组

js 复制代码
interface X {
    name:string,
    age?:number
}

let arr:X[]=[{name:'123'}]

定义多维数组

js 复制代码
let arr: number[][] = [[1], [2]]
let arr1: Array<Array<number>> = [[1], [2]]

元组定义数组

js 复制代码
let arr2:[number,string] = [1,'2']

定义arguments类数组

js 复制代码
function Arr(...args:any): void {
    console.log(arguments)
    //错误的arguments 是类数组不能这样定义
    let arr:number[] = arguments
}
Arr(111, 222, 333)
 
 
 
function Arr(...args:any): void {
    console.log(arguments) 
    //ts内置对象IArguments 定义
    let arr:IArguments = arguments
}
Arr(111, 222, 333)
 
//其中 IArguments 是 TypeScript 中定义好了的类型,它实际上就是:
interface IArguments {
[index: number]: any;
length: number;
callee: Function;
}
相关推荐
_Kayo_4 分钟前
node.js 学习笔记3 HTTP
笔记·学习
CCCC13101633 小时前
嵌入式学习(day 28)线程
jvm·学习
星星火柴9364 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
小狗爱吃黄桃罐头4 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
艾莉丝努力练剑5 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
烛阴5 小时前
前端必会:如何创建一个可随时取消的定时器
前端·javascript·typescript
武昌库里写JAVA6 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
杜子不疼.6 小时前
《Python学习之字典(一):基础操作与核心用法》
开发语言·python·学习
小幽余生不加糖7 小时前
电路方案分析(二十二)适用于音频应用的25-50W反激电源方案
人工智能·笔记·学习·音视频
..过云雨7 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习