TypeScript 中 interface 和 type 的使用#记录

一、interface:接口

interface A{label: string;
}const aa = ((aObj: A) => {console.log(aObj.label);//'123'return aObj.label;
})aa({label: '123'})

1、可选属性

interface A{label: string;age?: number;
}

2、只读属性

interface A{label: string;age?: number;readonly sex: string;
}

3、多余属性检查

interface A{label: string;age?: number;readonly sex: string;
}const aa = ((aObj: A) => {console.log(aObj.label);return aObj.label;
})aa({label: '123', age: 12, sex: '男',name: '123'})// 报错//避免以上报错只需加上[propName:strig]:any
interface B{label: string;age?: number;readonly sex: string;[propName:string]:any;
}const bb = ((aObj: B) => {console.log(aObj.label);return aObj.label;
})bb({label: '123', age: 12, sex: '男',name: '123'})// 正常

4、函数类型

interface A{(a:number,b:number):void;
}

5、索引类型

interface A{[index: number]: string
}const arr: A = ['a', 'b', 'c']

6、类类型接口

interface A{name: string;age: number;
}class B implements A{name: string;age: number;constructor(name: string, age: number){this.name = name;this.age = age;}sayHello(){console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);}
}const b = new B("Alice", 25);

7、继承多个接口

interface A{name: string;
}interface B{age: number;
}interface C extends A, B{gender: string;
}const c: C = {name: "John",age: 30,gender: "male"
}

二、type:类型别名

type 会给一个类型起个新名字。 type 有时和 interface 很像,但是可以作用于原始值(基本类型),联合类型,元组以及其它任何你需要手写的类型。

type A = stringtype B = () => numbertype C = A | Bconst c = ((value: C) =>{if (typeof value === 'string') {return value}return value()
})

1、同接口一样,类型别名也可以是泛型 - 我们可以添加类型参数并且在别名声明的右侧传入
 

type A<T> = { value: T };

2、也可以使用类型别名来在属性里引用自己

type A<T> = {value: T;a: A<T>;
}

3、与交叉类型一起使用,我们可以创建出一些十分稀奇古怪的类型。

type B<T> = T & { next: B<T> };interface C{name: string;
}let c: B<C>;
let s = c.name;
let s = c.next.name;
let s = c.next.next.name;
let s = c.next.next.next.name;

 4、类型别名不能出现在声明右侧的任何地方

type A= Array<A>; // 错误

三、interface和type区别

1、两者都可以用来描述对象或函数的类型,但是语法不同。

//interfaceinterface Point {x: number;y: number;
}interface SetPoint {(x: number, y: number): void;
}//typetype Point = {x: number;y: number;
};type SetPoint = (x: number, y: number) => void;

2、与接口不同,类型别名还可以用于其他类型

//基本类型和联合类型可以看上面举的例子// tuple
type Data = [number, string];// dom
let div = document.createElement('div');
type B = typeof div;

3、两者都可以扩展,但是语法又有所不同。此外,请注意接口和类型别名不是互斥的。接口可以扩展类型别名,反之亦然。

//1、接口继承接口interface PartialPointX { x: number; }
interface Point extends PartialPointX { y: number; }//2、类别集成类别type PartialPointX = { x: number; };
type Point = PartialPointX & { y: number; };//3、接口继承类别type PartialPointX = { x: number; };
interface Point extends PartialPointX { y: number; }//4、类别继承接口interface PartialPointX { x: number; }
type Point = PartialPointX & { y: number; };

4、接口可以定义多次,并将被视为单个接口(合并所有声明的成员)。

interface Point { x: number; }
interface Point { y: number; }const point: Point = { x: 1, y: 2 };

5、计算属性,生成映射类型

type 能使用 in 关键字生成映射类型,但 interface 不行。

type Keys = "firstname" | "surname"type DudeType = {[key in Keys]: string
}const test: DudeType = {firstname: "Pawel",surname: "Grzybek"
}// 报错
//interface DudeType2 {
//  [key in keys]: string
//}

 5、导出的时候也有不同

export default interface Config {name: string
}// export default type Config1 = {
//   name: string
// }
// 会报错type Config2 = {name: string
}
export default Config2

三、总结

类型:对象、函数两者都适用,但是 type 可以用于基础类型、联合类型、元祖。

同名合并:interface 支持,type 不支持。

计算属性:type 支持, interface 不支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/827400.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

231 基于matlab的北斗信号数据解析

基于matlab的北斗信号数据解析&#xff0c;多通道和单通道接收到的北斗信号数据&#xff0c;利用接收到的北斗数据&#xff08;.dat .txt文件&#xff09;&#xff0c;进行解析&#xff0c;得到初始伪距&#xff0c;平滑伪距&#xff0c;载波相位&#xff0c;并计算其标准差&am…

代码随想录训练营23day-贪心算法

一、贪心算法 贪心算法核心思想是局部最优&#xff0c;以确定全局最优。当然需要使用数学归纳去总结&#xff0c;但是实际应用过程&#xff0c;可以举反例来验证是不是可以使用贪心算法。参考代码随想录 贪心算法一般分为如下四步&#xff1a; 将问题分解为若干个子问题找出…

翱途开发平台新手上路-体验APP移动手机办公

O2OA(翱途)开发平台拥有配套的移动办公APP&#xff0c;支持IOS和安卓端&#xff0c;用户可在连接O2云之后&#xff0c;使用APP使用移动办公。移动办公APP开放源代码&#xff0c;不会产生任何费用。本篇主要简单讲述初如何完成服务器连接O2云&#xff0c;实现移动办公。 一、先决…

Barnes-Hut t-SNE:大规模数据的高效降维算法

在数据科学和分析中&#xff0c;理解高维数据集中的底层模式是至关重要的。t-SNE已成为高维数据可视化的有力工具。它通过将数据投射到一个较低维度的空间&#xff0c;提供了对数据结构的详细洞察。但是随着数据集的增长&#xff0c;标准的t-SNE算法在计算有些困难&#xff0c;…

什么是IoT?

什么是IoT&#xff1f; IoT&#xff0c;即物联网&#xff08;Internet of Things&#xff09;&#xff0c;是通过信息传感设备和互联网将各种物品连接起来&#xff0c;实现智能化的识别、定位、跟踪、监控和管理的网络系统。 以下是关于IOT的一些详细解释&#xff1a; 基本概…

JVM之本地方法栈和程序计数器和堆

本地方法栈 本地方法栈是为虚拟机执行本地方法时提供服务的 JNI&#xff1a;Java Native Interface&#xff0c;通过使用 Java 本地接口程序&#xff0c;可以确保代码在不同的平台上方便移植 不需要进行 GC&#xff0c;与虚拟机栈类似&#xff0c;也是线程私有的&#xff0c;…

OCP Java17 SE Developers 复习题13

答案 D, F. There is no such class within the Java API called ParallelStream, so options A and E are incorrect. The method defined in the Stream class to create a parallel stream from an existing stream is parallel(); therefore, option F is correct, and o…

Spring源码中的抽象工厂模式

Spring 框架中广泛运用了抽象工厂模式来实现其核心组件的创建与管理。以下是源码分析&#xff1a; 源码分析&#xff1a; 1. BeanFactory 与其实现 org.springframework.beans.factory.BeanFactory 是 Spring 中最基础的工厂接口&#xff0c;它代表了抽象工厂模式中的“抽象…

Spring Boot分段处理List集合多线程批量插入数据

项目场景&#xff1a; 大数据量的List集合&#xff0c;需要把List集合中的数据批量插入数据库中。 解决方案&#xff1a; 拆分list集合后&#xff0c;然后使用多线程批量插入数据库 1.实体类 package com.test.entity;import lombok.Data;Data public class TestEntity {priv…

Python入门:使用Python实现简单的猜数字游戏

Python是一种解释型、交互式、面向对象的编程语言&#xff0c;其设计哲学强调代码的可读性&#xff0c;并允许开发者用少量代码表达想法。在本文中&#xff0c;我们将通过编写一个简单的猜数字游戏来展示Python的基础知识和编程逻辑。 游戏描述 游戏开始时&#xff0c;程序会…

数字化转型过程中所面临的挑战以及应对这些挑战的策略

随着信息技术的快速发展&#xff0c;企业为了提升运营效率、优化资源配置&#xff0c;往往会在不同部门建立各自的信息系统。然而&#xff0c;这些系统的孤立性、功能重叠以及数据不一致性等问题逐渐凸显&#xff0c;导致企业业务流程受阻&#xff0c;难以形成高效的协同作战能…

Spring源码中的简单工厂模式

Spring 源码中广泛运用了各种设计模式,其中包括简单工厂模式。简单工厂模式在 Spring 中主要用于简化对象的创建过程,将对象的创建逻辑集中管理,从而使得客户端代码无需关心具体的对象创建细节,只需与工厂交互就能获取所需的对象实例。这种设计有助于提高代码的可读性、可维…

高斯溅射融合之路(一)- webgl渲染3d gaussian splatting

大家好&#xff0c;我是山海鲸的技术负责人。之前已经写了一个GIS融合系列。其实CesiumJS的整合有相当的难度&#xff0c;同时也有很多方面的工作&#xff0c;很难在几篇文章内写完&#xff0c;整个山海鲸团队也是投入了接近两年的时间&#xff0c;才把周边整套工具链进行了完善…

prometheus服务端部署

prometheus 安装 下载 # https://prometheus.io/download/wget https://github.com/prometheus/prometheus/releases/download/v2.34.0/prometheus-2.34.0.linux-amd64.tar.gztar -zxf prometheus-2.34.0.linux-amd64.tar.gz -C /data0/prometheus-2.34.0sudo adduser prome…

Linux中inode号与日志分析

一.inode号 1.inode表结构 元信息&#xff1a;每个文件的属性信息&#xff0c;比如&#xff1a;文件的大小&#xff0c;时间&#xff0c;类型&#xff0c;权限等&#xff0c;称为文件的元数据(meta data 元信息 ) 元数据是存放在inode&#xff08;index node&#xff09;表中…

Spring Kafka—— KafkaListenerEndpointRegistry 隐式注册分析

由于我想在项目中实现基于 Spring kafka 动态连接 Kafka 服务&#xff0c;指定监听 Topic 并控制消费程序的启动和停止这样一个功能&#xff0c;所以就大概的了解了一下 Spring Kafka 的几个重要的类的概念&#xff0c;内容如下&#xff1a; ConsumerFactory 作用&#xff1a;…

Opencv_2_ 图像色彩空间转换

ColorInvert.h 内容如下&#xff1a; #pragma once #include <opencv.hpp> using namespace std; #include <opencv.hpp> using namespace cv; using namespace std; class ColorInvert{ public : void colorSpaceInvert(Mat&image); }; ColorInvert.cpp…

使用了Python语言和Flask框架。创建一个区块链网络,允许用户通过HTTP请求进行交互,如包括创建区块链、挖矿、验证区块链等功能。

目录 大概来说&#xff1a; 二、代码注释 1.添加交易方法&#xff08;add_transaction函数&#xff09; 2.添加新的节点&#xff08;add_node 函数&#xff09; 3、替换链的方法&#xff08;replace_chain函数&#xff09; 总结 大概来说&#xff1a; 定义了一个名为Blo…

1、初识Linux系统 shell 脚本

shell脚本组成介绍 1、shell脚本命名规则 必须以.sh文件结尾&#xff0c;类似.txt文件&#xff1b;例如创建一个test.sh文件 2、linux系统中shell脚本开头&#xff0c;必须以如下代码开头 test.sh内容如下&#xff1a; #!/bin/bash# 这是一个注释echo "Hello, World!&…

西安地区调频广播频率一览

FM89.6 陕西人民广播电台经济广播 FM91.6 陕西人民广播电台交通广播 FM93.1 西安人民广播电台音乐广播 FM95.5 中央人民广播电台音乐之声 FM96.4 中央人民广播电台中国之声 FM98.8 陕西人民广播电台音乐广播 FM101.1 陕西人民广播电台戏曲广播 FM101.8 陕西人民广播电台…