Vue 如何简单更快的对 TypeScript 中接口的理解?应用场景?

TypeScript 中接口(Interface)的理解与应用

在 TypeScript 中,接口(Interface) 是一种用来定义对象的结构或形状的方式。接口可以指定对象中应该包含哪些属性、这些属性的类型以及它们的函数签名。接口帮助我们在代码中确保数据结构的正确性,并且能够提高代码的可读性和可维护性。

1. 接口的基本使用

接口定义了一个“合同”,它强制实施类或对象遵守某种结构。我们可以通过接口指定对象的属性和方法。

例子:

// 定义接口
interface Person {name: string;age: number;
}// 使用接口
const person: Person = {name: "Alice",age: 30
};

在上面的例子中,我们定义了一个 Person 接口,指定 Person 对象必须有 nameage 两个属性,并且分别是 stringnumber 类型。

2. 可选属性

接口的属性可以是可选的,通过在属性名后面加上 ? 来实现。这意味着对象可以有这些属性,也可以没有。

例子:

interface Person {name: string;age: number;address?: string;  // 可选属性
}const person1: Person = {name: "Alice",age: 30
};const person2: Person = {name: "Bob",age: 25,address: "123 Main St"
};

在这个例子中,address 是可选的,因此 person1 可以没有 address 属性,person2 可以有 address 属性。

3. 只读属性

接口的属性可以是只读的,这意味着一旦对象被创建后,属性值不能被修改。通过使用 readonly 关键字来定义只读属性。

例子:

interface Person {readonly id: number;name: string;age: number;
}const person: Person = {id: 1,name: "Alice",age: 30
};// person.id = 2;  // 错误:不能修改只读属性

在上面的代码中,id 是只读属性,因此不能在创建后修改它的值。

4. 函数类型接口

接口还可以定义函数的类型,描述函数的输入和输出。

例子:

interface Greeter {(name: string): string;
}const greet: Greeter = (name) => {return `Hello, ${name}!`;
};console.log(greet("Alice")); // 输出 "Hello, Alice!"

在这个例子中,Greeter 接口定义了一个函数类型,要求该函数接收一个 string 类型的参数,并返回一个 string 类型的结果。

5. 接口继承

接口可以通过继承来扩展其他接口的属性。继承后的接口可以继承原接口的所有属性和方法。

例子:

interface Animal {name: string;age: number;
}interface Dog extends Animal {breed: string;
}const myDog: Dog = {name: "Buddy",age: 5,breed: "Golden Retriever"
};

在这个例子中,Dog 接口继承了 Animal 接口的 nameage 属性,同时添加了一个新的属性 breed

6. 类与接口

接口不仅可以用于普通对象,也可以用于类。类可以通过实现接口来确保它遵守接口的约定。

例子:

interface Person {name: string;age: number;greet(): void;
}class Employee implements Person {name: string;age: number;jobTitle: string;constructor(name: string, age: number, jobTitle: string) {this.name = name;this.age = age;this.jobTitle = jobTitle;}greet(): void {console.log(`Hello, my name is ${this.name}, and I am a ${this.jobTitle}.`);}
}const emp = new Employee("Alice", 30, "Software Engineer");
emp.greet();  // 输出 "Hello, my name is Alice, and I am a Software Engineer."

在这个例子中,Employee 类实现了 Person 接口,确保类具有 nameage 属性和 greet 方法。

7. 多重接口实现

一个类可以实现多个接口,TypeScript 允许一个类实现多个接口。

例子:

interface Flyable {fly(): void;
}interface Swimmable {swim(): void;
}class Duck implements Flyable, Swimmable {fly(): void {console.log("Flying...");}swim(): void {console.log("Swimming...");}
}const duck = new Duck();
duck.fly();  // 输出 "Flying..."
duck.swim(); // 输出 "Swimming..."

在这个例子中,Duck 类实现了 FlyableSwimmable 两个接口,必须实现这两个接口中的方法。

8. 应用场景

8.1 配置对象和函数参数类型

接口常用于定义复杂配置对象或函数的参数类型,确保传入的数据结构正确。

interface Config {host: string;port: number;secure: boolean;
}function connect(config: Config) {console.log(`Connecting to ${config.host}:${config.port} with secure=${config.secure}`);
}const config: Config = {host: "localhost",port: 8080,secure: true
};connect(config);  // 输出 "Connecting to localhost:8080 with secure=true"
8.2 数据模型定义

接口在应用开发中常用于定义数据模型,特别是在处理复杂的数据结构时。

interface Product {id: number;name: string;price: number;
}const product: Product = {id: 1,name: "Laptop",price: 1000
};
8.3 类型约束与类型安全

接口提供了一种强类型的方式来约束对象的形状,可以帮助我们在开发过程中避免一些类型错误。

interface Point {x: number;y: number;
}function calculateDistance(p1: Point, p2: Point): number {return Math.sqrt(Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2));
}const point1: Point = { x: 0, y: 0 };
const point2: Point = { x: 3, y: 4 };console.log(calculateDistance(point1, point2)); // 输出 5
8.4 组件设计与接口的使用

在前端开发中,特别是在 React 或 Vue 等框架中,接口经常用于定义组件的 props 类型。

interface ButtonProps {label: string;onClick: () => void;
}const Button = ({ label, onClick }: ButtonProps) => {return <button onClick={onClick}>{label}</button>;
};

9. 总结

  • 接口 是 TypeScript 中一种非常重要的结构,能够帮助我们定义对象的形状和结构。
  • 接口能定义必选属性可选属性只读属性,并且可以定义函数类型类的结构
  • 接口非常适合用于定义数据模型函数参数类型组件 props 类型等场景,增强代码的类型安全、可读性和可维护性。

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

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

相关文章

SAP PI/PO Proxy2JDBC SQL_QUERY动态接口示例

目录 背景&#xff1a; 完整demo步骤&#xff1a; IR: ID: SPROXY: 测试代码&#xff1a; 注意点&#xff1a; 背景&#xff1a; 中途临时帮客户项目做其他功能&#xff0c;项目上有部分开发项需要通过PO去第三方数据库取数&#xff0c;项目上的开发对PO不太熟&#xf…

如何使用本地大模型做数据分析

工具&#xff1a;interpreter --local 样本数据&#xff1a; 1、启动分析工具 2、显示数据文件内容 输入&#xff1a; 显示/Users/wxl/work/example_label.csv 输出&#xff1a;(每次输出的结果可能会不一样&#xff09; 3、相关性分析 输入&#xff1a; 分析客户类型与成…

中间件--laravel进阶篇

laravel版本11.31,这中间件只有3种,分别是全局中间件,路由中间件,控制器中间件。相比thinkphp8,少了一个应用中间件。 一、创建中间件 laravel创建中间件可以使用命令的方式创建,非常方便。比如php artisan make:middleware EnsureTokenIsValid。EnsureTokenIsValid是中间…

一维卷积神经网络(1D-CNN)

一维卷积神经网络&#xff08;1D Convolutional Neural Network, 1D CNN&#xff09;是卷积神经网络的一种变体&#xff0c;专门用于处理序列数据&#xff0c;如时间序列、文本等。 一、基本结构 一维卷积神经网络的基本结构与二维卷积神经网络&#xff08;2D CNN&#xff09;类…

Java中的TreeSet集合解析

记一下java流处理的操作 1.去重&#xff0c;按照billTypeCode去重 list list.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getBillTypeCode()))), ArrayList::new)); 排序&#x…

vue中mixin(混入)的使用

目录 mixin(混入) 使用方式 第一步定义混合 ​编辑 第二步使用混入 局部混入 全局混合 mixin(混入) 功能&#xff1a;可以把多个组件共用的配置提取成一个混入对象 使用方式 第一步定义混合 { data(){....}, methods:{....} .... } 第二步使用混入 …

vue中路由缓存

vue中路由缓存 问题描述及截图解决思路关键代码及打印信息截图 问题描述及截图 在使用某一平台时发现当列表页码切换后点击某一卡片进入详情页后&#xff0c;再返回列表页时页面刷新了。这样用户每次看完详情回到列表页都得再重新输入自己的查询条件&#xff0c;或者切换分页到…

Easyexcel(1-注解使用)

相关文章链接&#xff1a; Easyexcel&#xff08;1-注解使用&#xff09; 版本依赖 <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.3.3</version> </dependency>ExcelProperty…

Vue3 -- mock数据完整配置并调试【项目集成6】

引言&#xff1a; ‌Mock在前端开发中的作用主要是模拟后端接口数据&#xff0c;以便前端开发者能够提前进行页面和功能的开发、调试&#xff0c;而无需等待后端提供真实的接口数据‌。Mock数据可以加速前后端开发的协同&#xff0c;避免因数据延迟导致的开发阻塞‌。【摘自百…

开源许可协议

何同学推动了开源协议的认识&#xff0c;功不可没&#xff0c;第一次对开源有了清晰的认识&#xff0c;最宽松的MIT开源协议 源自OSC开源社区&#xff1a;何同学使用开源软件“翻车”&#xff0c;都别吵了&#xff01;扯什么违反MIT

数据结构(顺序栈——c语言实现)

栈的基本概念&#xff1a; 栈是限制在一端进行插入操作和删除操作的线性表&#xff08;俗称堆栈&#xff09;&#xff0c;允许进行操作的一端称为“栈顶”&#xff0c;另一固定端称为“栈底”&#xff0c;当栈中没有元素时称为“空栈” 特点&#xff1a;先进后出&#xff08;FI…

【智谱清言-注册_登录安全分析报告】

前言 由于网站注册入口容易被机器执行自动化程序攻击&#xff0c;存在如下风险&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露&#xff0c;不符合国家等级保护的要求。短信盗刷带来的拒绝服务风险 &#xff0c;造成用户无法登陆、注册&#xff0c;大量收到垃圾短信的…

[Realtek sdk-3.4.14b] RTL8197FH-VG新增jffs2分区操作说明

sdk说明 ** Gateway/AP firmware v3.4.14b – Aug 26, 2019**  Wireless LAN driver changes as:  Refine WiFi Stability and Performance  Add 8812F MU-MIMO  Add 97G/8812F multiple mac-clone  Add 97G 2T3R antenna diversity  Fix 97G/8812F/8814B MP issu…

Cesium 加载B3DM模型

一、引入Cesium&#xff0c;可以使用该链接下载cesium 链接: https://pan.baidu.com/s/1BRQyaFCkxO2xQQT5RzFUCw?pwdkcv9 提取码: kcv9 在index.html文件中引入cesium <script type"text/javascript" src"/Cesium/Cesium.js"></script> …

掌握移动端性能测试利器:深入JMeter手机录制功能

引言 在当今移动互联网时代&#xff0c;应用程序的性能和用户体验至关重要。为了确保应用程序在不同设备和网络环境下都能稳定运行&#xff0c;性能测试成为了不可或缺的一环。Apache JMeter作为一款强大的开源性能测试工具&#xff0c;不仅支持传统的PC端性能测试&#xff0c…

友思特新闻 | 友思特荣获广州科技创新创业大赛智能装备行业赛初创组优胜企业!

2024年11月19日&#xff0c;第十三届中国创新创业大赛&#xff08;广东广州赛区&#xff09;暨2024年广州科技创新创业大赛智能装备行业赛颁奖典礼隆重举行。 赛事奖项介绍&#xff1a;广州科技创新创业大赛智能装备行业赛 第十三届“中国创新创业大赛&#xff08;广东广州赛区…

Docker3:docker基础1

欢迎来到“雪碧聊技术”CSDN博客&#xff01; 在这里&#xff0c;您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者&#xff0c;还是具有一定经验的开发者&#xff0c;相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导&#xff0c;我将…

MySQL - 数据库基础 | 数据库操作 | 表操作

文章目录 1、数据库基础1.1为什么要有数据库1.2主流的数据库1.3连接MySQL1.4服务器、数据库、表的关系1.5 MySQL框架1.6 SQL分类1.7储存引擎 2.数据库操作2.1创建数据库2.2字符集和校验规则2.3删除数据库2.4修改数据库2.5备份与恢复2.6查看连接情况 3.表的操作3.1创建表3.2查看…

通过vite+vue3+pinia从0到1搭建一个uniapp应用

最近项目上要做一个app&#xff0c;选择了用uniapp作为开发框架&#xff1b;我大概看了一下uniapp的文档&#xff0c;根据文档从0到1搭了一个uniapp应用供大家参考。 因为本人习惯使用了WebStorm编译器&#xff0c;但是uniapp官方推荐使用HBuilder搭建&#xff0c;如果和我一样…

学习路之phpstudy--安装mysql5.7后在my.ini文件中无法修改sql_mode

windows环境下使用phpstudy安装mysql5.7后需要修改mysql中的sql_mode配置&#xff0c;但是在phpstudy中打开mysql配置文件my.ini后&#xff0c; 通过查找找不到sql_mode或sql-mode&#xff0c; 此时无法在my.ini文件中直接进行修改&#xff0c;可以使用mysql命令进行修改&#…