برنامه نویسی

درک تفاوت بین رابط ها و انواع در TypeScript

در TypeScript، هر دو رابط و انواع به عنوان ابزار قدرتمندی برای تعریف انواع و ساختارهای سفارشی عمل می کنند. به عنوان توسعه دهندگان ارشد، درک زمان استفاده از هر ساختار برای به حداکثر رساندن خوانایی و قابلیت نگهداری کد بسیار مهم است. در این مقاله، تفاوت‌های بین رابط‌ها و انواع را بررسی می‌کنیم و بینش‌هایی را در مورد بهترین موارد استفاده آنها ارائه می‌کنیم.

رابط ها

واسط ها در TypeScript قراردادهایی را تعریف می کنند که یک شی باید به آنها پایبند باشد. آنها شکل یک شی را با توصیف خواص، روش ها و انواع مربوط به آن مشخص می کنند. رابط‌ها به ما اجازه می‌دهند تا یکپارچگی را اعمال کنیم و طرحی برای دنبال کردن اشیا ارائه کنیم.

در اینجا یک مثال از یک رابط نشان دهنده یک شی Person است:

interface Person {
  name: string;
  age: number;
  greet(): void;
}
وارد حالت تمام صفحه شوید

از حالت تمام صفحه خارج شوید

رابط ها را می توان توسط کلاس ها پیاده سازی کرد و اطمینان حاصل کرد که ساختار کلاس با رابط تعریف شده مطابقت دارد. این امر سازماندهی کد را ارتقا می دهد و کار با سلسله مراتب شی پیچیده را آسان تر می کند.

class Employee implements Person {
  name: string;
  age: number;

  constructor(name: string, age: number) {
    this.name = name;
    this.age = age;
  }

  greet() {
    console.log(`Hello, I'm ${this.name}!`);
  }
}
وارد حالت تمام صفحه شوید

از حالت تمام صفحه خارج شوید

هنگامی که نیاز به تعریف قرارداد اشیاء با رفتار مشترک دارید، رابط ها عالی هستند، زیرا آنها بر روی شکل و جزئیات پیاده سازی تمرکز می کنند.

انواع

از سوی دیگر، انواع نسبت به رابط‌ها انعطاف‌پذیرتر و همه‌کاره‌تر هستند. آنها می توانند ساختارهای داده مختلف، از جمله انواع اولیه، انواع اتحادیه، تاپل ها و موارد دیگر را نشان دهند. انواع به شما امکان می دهد نام مستعار برای انواع موجود ایجاد کنید، کد شما را گویاتر می کند و تکرار را کاهش می دهد.

این مثال را در نظر بگیرید که در آن یک نوع سفارشی تعریف می کنیم Point نشان دهنده یک مختصات دو بعدی:

type Point = {
  x: number;
  y: number;
};
وارد حالت تمام صفحه شوید

از حالت تمام صفحه خارج شوید

نوع ها به ویژه هنگام کار با تبدیل داده های پیچیده مفید هستند، مانند نگاشت یک نوع به نوع دیگر یا ایجاد انواع اتحادیه که ساختارهای مختلف را ترکیب می کنند.

type Circle = {
  center: Point;
  radius: number;
};

type Rectangle = {
  topLeft: Point;
  width: number;
  height: number;
};

type Shape = Circle | Rectangle;
وارد حالت تمام صفحه شوید

از حالت تمام صفحه خارج شوید

استفاده از انواع به شما امکان می دهد ساختارهایی را نشان دهید که به راحتی نمی توان آنها را با رابط ها بیان کرد و انعطاف پذیری بیشتری را در تعریف انواع سفارشی فراهم می کند.

زمان استفاده از هر کدام

بنابراین، چه زمانی باید از رابط ها یا انواع استفاده کنید؟ در اینجا چند دستورالعمل برای در نظر گرفتن وجود دارد:

  • از رابط ها استفاده کنید:

    • هنگام تعریف شکل و قرارداد اشیا، تمرکز بر جزئیات اجرای آنها.
    • هنگام کار با کلاس هایی که باید به ساختار خاصی پایبند باشند.
    • هنگامی که می خواهید چندین رابط را گسترش یا پیاده سازی کنید.
  • از انواع استفاده کنید:

    • هنگام ایجاد نام مستعار نوع سفارشی که چندین نوع موجود را ترکیب می کند.
    • هنگام کار با ساختارهای داده پیچیده و تبدیل.
    • هنگام استفاده از انواع اتحاد یا نمایش ساختارهایی که نمی توانند به تنهایی با رابط ها بیان شوند.

به یاد داشته باشید، هر دو رابط و انواع می توانند در پایگاه کد شما وجود داشته باشند. مهم است که از نقاط قوت آنها استفاده کنید و ساختار مناسب را بر اساس نیازهای خاص پروژه خود انتخاب کنید.

نتیجه

رابط ها و انواع ساختارهای اساسی در TypeScript هستند که قابلیت های مختلفی را برای تعریف انواع سفارشی ارائه می دهند. با درک تفاوت های آنها و بهترین موارد استفاده، می توانید کدهای رسا، خوانا و قابل نگهداری بنویسید. رابط ها تعریف شکل مبتنی بر قرارداد را ارائه می دهند، در حالی که انواع، تطبیق پذیری و انعطاف پذیری را ارائه می دهند. استفاده از نقاط قوت هر ساختار به شما قدرت می دهد تا پایگاه های کد TypeScript قوی ایجاد کنید.

بیایید قدرت TypeScript را در آغوش بگیریم و ابزار مناسب را برای کار انتخاب کنیم!

برنامه نویسی مبارک، توسعه دهندگان همکار!

نوشته های مشابه

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

دکمه بازگشت به بالا