Typescript之接口(Interface)

article/2025/9/25 12:26:35

我们可以通过Interface关键字来定义限制数据的类型。

1.给对象定义类型

/*** 定义一种类型,名称叫做PersonInfo,里面有三个属性* @name 人物的名字,类型为string* @age 人物的年龄,类型为number* @say 人物的方法,类型为函数类型,函数传递一个参数,参数类型为string,返回值类型为void*/
interface PersonInfo{name:string,age:numbersay:(content:string)=>void
}

使用定义好的PersonInfo类型

/*** 定义p1的类型是PersonInfo类型的变量,所以p1只能有name,age,say三个属性* 且name必须是string,age必须是number,say必须是定义的函数类型*/
const p1 : PersonInfo ={name:'小明',age:18,say(content){console.log(content);}
}console.log(p1.name);
console.log(p1.age);
console.log(p1.say('饿了!'));

2.定义数组类型

//用于对象
let newObj :ArrType = {0:0,1:'1'
}
/*** ArrType中0,1可以用于表示数组的下标,也可以用于表示对象的属性0和1* 用在数组中表示数组的第一个元素是number类型,第二个元素是string类型*/
interface ArrType{0:number,1:string
}
let newArr : ArrType = [0,'1'];

3.定义数组中的元素的类型(常用)

/***  PersonGender是定义的枚举类型,其中有两个值,MALE和FEMALE*/
enum PersonGender{MALE = "女",FEMALE = "男"
}/*** ArrElementType接口中有三个属性* @name : string类型* @age : number类型* @gender : 枚举类型(PersonGender)*/
interface ArrElementType {name: string;age: number;gender: PersonGender;
}/*** let arrElement: ArrElementType 表示定义一个ArrElementType类型的变量* let arrElement: ArrElementType[] 表示定义一个ArrElementType类型的数组,数组中的每个元素类型都是ArrElementType*/
let arrElement: ArrElementType[] = [{name: "菲菲",age: 18,gender: PersonGender.MALE,},{name: "铭铭",age: 19,gender: PersonGender.FEMALE,},
];console.log(arrElement);

输出结果:

 

 

这个方法在工作中经常可以用到,比如后端返回的某个人物或者其它的信息,一般都是可以拿到数组结果的data,里面每个元素都是{}这种形式的,我们可以根据后台返回的数据,设置数据的类型,传给UI组件。


http://chatgpt.dhexx.cn/article/A0prb9uc.shtml

相关文章

astype

anp.array([1.1,1.2]) print(a数据类型:,a.dtype) print(astype修改数据类型:,a.astype(float).dtype) print(原数据类型未改变,a.dtype)#正确操作 aa.astype(float32) print(修改类型后再次操作,类型改变:,a.dtype) ba.astype(in…

TypeScript中的interface和type区别

💂 个人网站: 【紫陌】【笔记分享网】 💅 想寻找共同学习交流、共同成长的伙伴, 请点击【前端学习交流群】 在 TypeScript中,type 和 interface有些相似,都可以给类型命名并通过该名字来引用表示的类型。不过它们之间使…

TypeScript接口——interface

目录 一、接口概述: 二、接口类型介绍: 1、属性接口: 2、 函数接口: 3、可索引接口: (1)可索引接口约束数组示例: (2) 可索引接口约束对象示例&#xf…

【TypeScript】接口类型 Interfaces 的使用理解

导语: 什么是 类型接口? 在面向对象语言中,接口(Interfaces)是一个很重要的概念,它是对行为的抽象,而具体如何行动需要由类(classes)去实现(implement&#x…

type 与 interface 的区别,你真的懂了吗?

大厂技术 高级前端 Node进阶 点击上方 程序员成长指北,关注公众号 回复1,加入高级Node交流群 在写 ts 相关代码的过程中,总能看到 interface 和 type 的身影。它们的作用好像都一样的,相同的功能用哪一个都可以实现,…

自定义字体 Typeface ttf

一、简介 有时候界面在设计app时会使用一些比较美观的字体,在安卓中使用起来也并不困难,随着安卓SDK的更新,它的实现方式也有所不同,该文章来看看怎么实现自定义字体。 二、普通方法 设置字体TextView.setTypeface(Typeface) pub…

TypeScript - Interfaces(接口)

目录 1、接口介绍 1.1 接口示例 2、可选属性 3、只读属性 4、额外的属性检查 5、函数类型 6、可索引的类型 7、类类型 7.1 类静态部分和实例部分 8、继承接口 9、混合类型 10、接口继承类 1、接口介绍 Ty…

type 与 interface

type 与 interface 官方文档是这么说的: For the most part, you can choose based on personal preference, and TypeScript will tell you if it needs something to be the other kind of declaration. If you would like a heuristic, use interface until you…

TypeScript中type和interface区别

typescript中interface介绍:TypeScript 中的接口 interface_疆~的博客-CSDN博客通常使用接口(Interface)来定义对象的类型。https://blog.csdn.net/qq_40323256/article/details/128478749 type type关键字是声明类型别名的关键字。用来给一…

TypeScript中interface 与 type的区别,你真的懂吗?

在写 ts 相关代码的过程中,总能看到 interface 和 type 的身影。它们的作用好像都一样的,相同的功能用哪一个都可以实现,也都很好用,所以也很少去真正的理解它们之间到底有啥区别, 分别在什么场景下使用,将…

Android 设置字体的三种方法(TypeFace)

http://blog.csdn.net/legend12300/article/details/69875816 Android系统默认字体支持四种字体,分别为: noraml (普通字体,系统默认使用的字体)sans(非衬线字体)serif (衬线字体)…

Android 之 Paint API —— Typeface (字型)

本节带来Paint API系列的最后一个API,Typeface(字型),由字义,我们大概可以猜到,这个 API是用来设置字体以及字体风格的,使用起来也非常的简单!下面我们来学习下Typeface的一些相关 的用法! 官方…

Pycham_python 安装 gherkin

1.File>Settings>Plusings> 在MarketPlace标签下,搜索gherkin,选择如下图所示,点击Install,安装成功后重启pycharm即可 2,打开feature文件,就会有格式显示了 转载于:https://www.cnblogs.com/aide…

学Selenium自动化需要知道的之Python测试框架

根据StackoverFlow网站的开发者调查,Python是2019年增长最快的编程语言。在整体排名中,它甚至超越了Java,排在第二位,成为最受喜爱的编程语言之一。 Python流行的几个原因之一是对测试自动化框架的广泛支持。大多数流行的Python框…

机器学习框架Chainer学习

chainer优势——边定义边运行 当下已有的深度学习框架使用的是“定义后运行”机制。即意味着,首先定义并且固化一个网络,再周而复始地馈入小批量数据进行训练。由于网络是在任何前向、反向计算前静态定义的,所有的逻辑作为数据必须事先嵌入网…

Jenkins - Hello World

开始 Jenkins 的第一行代码 无论学哪种语言,都是从 hello world 开始,因为这个学会了,就说明你已经从入门到精通了。 让我们来看看 Jenkins 的 hello world 吧 0. 登录 Jenkins 1. 新建 item 2. 创建一个 Freestyle project 3. 增加执行命令…

Cucumber--基于vue前端的自动化测试(四)

cucumber是BDD (Behavior-driven development,行为驱动开发)的一个自动化测试的副产品。它使用自然语言来描述测试,使得非程序员可以理解他们。Gherkin是这种自然语言测试的简单语法,而Cucumber是可以执行它们的工具。 cucumber本质上是使用根…

【Jenkins】【Jenkins 使用】Jenkins 与 Git

【文章末尾给大家留下了大量的福利】 1、概述 Jenkins 与 Git 的结合使用,可以理解为是 Jenkins 的一个强大之处。为什么要这么说,简要说明一下这个工作模式就能理解: 一个软件项目,开发过程中通常都会使用到一些源码管理工具&am…

SSH and GPG keys

问题:gitgithub.com: Permission denied (publickey). fatal: Could not read from remote repository. gitgithub.com:权限被拒绝(publickey)。 我相信很多程序员开始都会对Git比较陌生。但是用过几次,就会觉得Git的功…