接口的基礎定義與屬性約束

在 TypeScript 中,接口(Interface)是一個非常強大且常用的特性。接口定義了對象的結構,包括對象的屬性和方法,可以為對象提供類型檢查和約束。通過接口,我們可以清晰地描述一個對象應該具備哪些屬性和方法。本文將介紹接口的基礎定義、屬性約束,以及一些常見的使用場景。

1. 什么是接口(Interface)?

接口是 TypeScript 中用于定義對象類型的方式,它提供了一種結構化的方式來描述對象的屬性和方法。接口不會生成代碼,它只是一個類型檢查的約束工具。

interface Person {name: string;age: number;
}const person: Person = {name: 'Alice',age: 30,
};

解釋

  • Person?接口定義了?name?和?age?兩個屬性,分別是?string?和?number?類型。
  • 變量?person?必須符合?Person?接口的結構,否則 TypeScript 會提示類型錯誤。
2. 接口的基本語法

接口的語法很簡單,使用 interface 關鍵字來聲明一個接口。接口中的每個屬性都可以指定類型,此外,接口還可以定義方法簽名。

interface Car {brand: string;model: string;year: number;drive(): void;
}const myCar: Car = {brand: 'Tesla',model: 'Model S',year: 2021,drive() {console.log('Driving the car...');},
};

解釋

  • Car?接口定義了四個成員:brandmodelyear?和?drive
  • drive?是一個方法,返回值類型為?void,表示沒有返回值。
  • 變量?myCar?必須滿足?Car?接口中的所有屬性和方法的要求。
3. 可選屬性

在接口中,有些屬性可能不是必須的,可以使用 ? 來標記屬性為可選屬性。這樣,定義接口時就不需要每個對象都包含這些可選屬性。

interface User {id: number;name: string;email?: string;  // 可選屬性
}const user1: User = { id: 1, name: 'John' };
const user2: User = { id: 2, name: 'Jane', email: 'jane@example.com' };

解釋

  • User?接口中的?email?屬性是可選的,表示對象可以沒有?email?屬性。
  • user1?沒有?email,是有效的對象;user2?包含了?email,也是有效的對象。
4. 只讀屬性

有時,我們希望某些屬性在對象創建后不能被修改。可以使用 readonly 關鍵字來定義只讀屬性。只讀屬性一旦被賦值后,就不能再修改。

interface Book {readonly title: string;author: string;
}const book: Book = { title: '1984', author: 'George Orwell' };
book.title = 'Animal Farm';  // 錯誤:title 是只讀屬性
book.author = 'Orwell';      // 正確:author 是可修改屬性

解釋

  • title?是只讀屬性,定義時加上?readonly?關鍵字,意味著對象創建后?title?的值不能被修改。
  • 試圖修改?book.title?會導致類型錯誤,而修改?author?則是允許的。
5. 方法簽名

接口不僅可以定義對象的屬性,還可以定義對象的方法簽名。方法簽名定義了方法的參數和返回類型,可以約束方法的輸入輸出。

interface Shape {area(): number;
}class Circle implements Shape {radius: number;constructor(radius: number) {this.radius = radius;}area(): number {return Math.PI * this.radius * this.radius;}
}const circle = new Circle(5);
console.log(circle.area());  // 輸出:78.53981633974483

解釋

  • Shape?接口定義了一個?area?方法,返回值類型為?number
  • Circle?類實現了?Shape?接口,并提供了?area?方法的具體實現。
6. 接口擴展

TypeScript 中的接口支持擴展,可以通過繼承其他接口來創建更復雜的接口。這樣可以復用已有的接口定義,避免重復代碼。

interface Vehicle {brand: string;model: string;
}interface ElectricVehicle extends Vehicle {batteryCapacity: number;
}const tesla: ElectricVehicle = {brand: 'Tesla',model: 'Model X',batteryCapacity: 100,
};

解釋

  • ElectricVehicle?接口通過?extends?關鍵字繼承了?Vehicle?接口,這意味著?ElectricVehicle?包含了?Vehicle?的所有屬性。
  • tesla?必須滿足?ElectricVehicle?接口的所有屬性要求,包括繼承自?Vehicle?的?brand?和?model?屬性,以及?ElectricVehicle?獨有的?batteryCapacity?屬性。
7. 接口與類的結合

接口與類結合使用時,類需要實現接口中的所有屬性和方法。類通過 implements 關鍵字實現接口,并且必須符合接口的結構要求。

interface Person {name: string;greet(): void;
}class Employee implements Person {name: string;position: string;constructor(name: string, position: string) {this.name = name;this.position = position;}greet() {console.log(`Hello, my name is ${this.name}, and I am a ${this.position}.`);}
}const employee = new Employee('Alice', 'Developer');
employee.greet();  // 輸出:Hello, my name is Alice, and I am a Developer.

解釋

  • Person?接口定義了?name?和?greet?方法,類?Employee?通過?implements?關鍵字來實現?Person?接口。
  • Employee?類必須提供?name?屬性和?greet?方法的具體實現,否則會報錯。
8. 使用接口進行類型檢查

接口不僅可以用于定義類的結構,還可以用來為對象字面量、函數參數等進行類型檢查。

function printPerson(person: Person): void {console.log(`Name: ${person.name}`);
}printPerson({ name: 'Alice' });  // 輸出:Name: Alice

解釋

  • printPerson?函數接收一個?Person?類型的參數,可以確保傳入的對象符合?Person?接口的結構。
  • 通過接口進行類型檢查,有助于避免傳入不符合結構的對象。
9. 總結

接口是 TypeScript 中非常強大的工具,它可以幫助我們定義對象的結構、方法簽名以及約束類型。通過接口,我們可以增強代碼的類型安全性,提升代碼的可讀性和可維護性。通過可選屬性、只讀屬性、接口繼承等特性,接口的應用變得更加靈活和強大。

掌握接口的定義與屬性約束,不僅能夠更好地規范代碼結構,還能減少潛在的錯誤,使得類型檢查更為嚴格。通過不斷實踐和使用接口,你可以提高自己編寫 TypeScript 代碼的能力,寫出更加健壯、清晰和高效的代碼。
希望這篇博客對你有所幫助!如果有任何問題或建議,歡迎留言討論。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/79485.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/79485.shtml
英文地址,請注明出處:http://en.pswp.cn/web/79485.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

高效全能PDF工具,支持OCR識別

軟件介紹 PDF XChange Editor是一款功能強大的PDF編輯工具,支持多種操作功能,不僅可編輯PDF內容與圖片,還具備OCR識別表單信息的能力,滿足多種場景下的需求。 軟件特點 這款PDF編輯器完全免費,用戶下載后直接…

OpenCV 中用于背景分割的一個類cv::bgsegm::BackgroundSubtractorGMG

操作系統:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 編程語言:C11 算法描述 cv::bgsegm::BackgroundSubtractorGMG 是 OpenCV 中用于背景分割的一個類,它實現了基于貝葉斯推理的背景建模算法(Bayesi…

MongoDB知識框架

簡介:MongoDB 是一個基于分布式文件存儲的數據庫,屬于 NoSQL 數據庫產品,以下是其知識框架總結: 一、數據模型 文檔:MongoDB 中的數據以 BSON(二進制形式的 JSON)格式存儲在集合中,…

WEBSTORM前端 —— 第2章:CSS —— 第8節:網頁制作2(小兔鮮兒)

目錄 1.項目目錄 2.SEO 三大標簽 3.Favicon 圖標 4.版心 5.快捷導航(shortcut) 6.頭部(header) 7.底部(footer) 8.banner 9.banner – 圓點 10.新鮮好物(goods) 11.熱門品牌(brand) 12.生鮮(fresh) 13.最新專題(topic) 1.項目目錄 【xtx-pc】 ima…

1、RocketMQ 核心架構拆解

1. 為什么要使用消息隊列? 消息隊列(MQ)是分布式系統中不可或缺的中間件,主要解決系統間的解耦、異步和削峰填谷問題。 解耦:生產者和消費者通過消息隊列通信,彼此無需直接依賴,極大提升系統靈…

[Linux網絡_71] NAT技術 | 正反代理 | 網絡協議總結 | 五種IO模型

目錄 1.NAT技術 NAPT 2.NAT和代理服務器 3.網線通信各層協議總結 補充說明 4.五種 IO 模型 1.什么是IO?什么是高效的IO? 2.有那些IO的方式?這么多的方式,有那些是高效的? 異步 IO 🎣 關鍵缺陷類比…

Unity基礎學習(八)時間相關內容Time

眾所周知,每一個游戲都會有自己的時間。這個時間可以是內部,從游戲開始的時間,也可以是外部真實的物理時間,時間相關內容 主要用于游戲中 參與位移計時 時間暫停等。那么我們今天就來看看Unity中和時間相關的內容。 Unity時間功能…

Java游戲服務器開發流水賬(1)游戲服務器的架構淺析

新項目立項停滯,頭大。近期讀老項目代碼看到Java,筆記記錄一下。 為什么要做服務器的架構 游戲服務器架構設計具有多方面的重要意義,它直接關系到游戲的性能、可擴展性、穩定性以及用戶體驗等關鍵因素 確保游戲的流暢運行 優化數據處理&a…

計算機視覺與深度學習 | 基于Transformer的低照度圖像增強技術

基于Transformer的低照度圖像增強技術通過結合Transformer的全局建模能力和傳統圖像增強理論(如Retinex),在保留顏色信息、抑制噪聲和平衡亮度方面展現出顯著優勢。以下是其核心原理、關鍵公式及典型代碼實現: 一、原理分析 1. 全局依賴建模與局部特征融合 Transformer的核…

Linux 文件目錄管理常用命令

pwd 顯示當前絕對路徑 cd 切換目錄 指令備注cd -回退cd …返回上一層cd ~切換到用戶主目錄 ls 列出目錄的內容 指令備注ls -a顯示當前目錄中的所有文件和目錄,包括隱藏文件ls -l以長格式顯示當前目錄中的文件和目錄ls -hl以人類可讀的方式顯示當前目錄中的文…

【Linux 系統調試】性能分析工具perf使用與調試方法

目錄 一、perf基本概念 1?. 事件類型? 2?. 低開銷高精度 3?. 工具定位? 二、安裝與基礎配置 1. 安裝方法 2. 啟用符號調試 三、perf工作原理 1. 數據采集機制 2. 硬件事件轉化流程 四、perf應用場景 1. 系統瓶頸定位 2. 鎖競爭優化 3. 緩存優化 五、perf高級…

嵌入式中屏幕的通信方式

LCD屏通信方式詳解 LCD屏(液晶顯示屏)的通信方式直接影響其數據傳輸效率、顯示刷新速度及硬件設計復雜度。根據應用場景和需求,LCD屏的通信方式主要分為以下三類,每種方式在協議類型、數據速率、硬件成本及適用場景上存在顯著差異…

【el-admin】el-admin關聯數據字典

數據字典使用 一、新增數據字典1、新增【圖書狀態】和【圖書類型】數據字典2、編輯字典值 二、代碼生成配置1、表單設置2、關聯字典3、驗證關聯數據字典 三、查詢操作1、模糊查詢2、按類別查詢(下拉框) 四、數據校驗 一、新增數據字典 1、新增【圖書狀態…

【Spring】Spring MVC筆記

文章目錄 一、SpringMVC簡介1、什么是MVC2、什么是SpringMVC3、SpringMVC的特點 二、HelloWorld1、開發環境2、創建maven工程a>添加web模塊b>打包方式:warc>引入依賴 3、配置web.xmla>默認配置方式b>擴展配置方式 4、創建請求控制器5、創建springMVC…

如何在大型項目中解決 VsCode 語言服務器崩潰的問題

在大型C/C項目中,VS Code的語言服務器(如C/C擴展)可能因內存不足或配置不當頻繁崩潰。本文結合系統資源分析與實戰技巧,提供一套完整的解決方案。 一、問題根源診斷 1.1 內存瓶頸分析 通過top命令查看系統資源使用情況&#xff…

LeetCode百題刷002摩爾投票法

遇到的問題都有解決的方案,希望我的博客可以為你提供一些幫助 圖片源自leetcode 題目:169. 多數元素 - 力扣(LeetCode) 一、排序法 題目要求需要找到多數值(元素個數>n/2)并返回這個值。一般會想到先…

Android Studio Gradle 中 只顯示 Tasks 中沒有 build 選項解決辦法

一、問題描述 想把項目中某一個模塊的代碼單獨打包成 aar ,之前是點擊 AndroidStudio 右側的 Gradle 選項,然后再點擊需要打包的模塊找到 build 進行打包,但是卻發現沒有 build 選項。 二、解決辦法 1、設置中勾選 Configure all Gradle tasks… 選項 …

深入淺出之STL源碼分析2_stl與標準庫,編譯器的關系

引言 在第一篇博客中,深入淺出之STL源碼分析1_vector基本操作-CSDN博客 我們將引出下面的幾個問題 1.剛才我提到了我的編譯器版本是g 11.4.0,而我們要講解的是STL(標準模板庫),那么二者之間的關系是什么?…

(十二)深入了解AVFoundation-采集:人臉識別與元數據處理

(一)深入了解AVFoundation:框架概述與核心模塊解析-CSDN博客 (二) 深入了解AVFoundation - 播放:AVFoundation 播放基礎入門-CSDN博客 (三)深入了解AVFoundation-播放&#xff1…

Kafka 與 RabbitMQ、RocketMQ 有何不同?

一、不同的誕生背景,塑造了不同的“性格” 名稱 背景與目標 產品定位 Kafka 為了解決 LinkedIn 的日志收集瓶頸,強調吞吐與持久化 更像一個“可持久化的分布式日志系統” RabbitMQ 出自金融通信協議 AMQP 的實現,強調協議標準與廣泛適…