درک انواع در تایپ اسکریپت – به زبان ساده

۴۷۲ بازدید
آخرین به‌روزرسانی: ۱۲ مهر ۱۴۰۲
زمان مطالعه: ۹ دقیقه
دانلود PDF مقاله
درک انواع در تایپ اسکریپت – به زبان سادهدرک انواع در تایپ اسکریپت – به زبان ساده

امروزه شاهد هستیم که اغلب کتابخانه‌ها از تایپ اسکریپت پشتیبانی می‌کنند و از این رو به احتمال بالا علاقه‌مند هستید که از تایپ اسکریپت در پروژه‌های آتی خود استفاده کنید. دقت کنید که به این منظور نوشتن کد در فایل ts. کفایت نمی‌کند، زیرا کامپایلر تایپ اسکریپت سختگیری کمی دارد و بسیاری از توسعه‌دهندگان میل دارند که کد جاوا اسکریپت را بدون هیچ نوع «توضیح نوع» (type annotations) بنویسند و این وضعیت موجب می‌شود که کل مزیت استفاده از انواع در تایپ اسکریپت از دست برود. در همین راستا و در ادامه این مطلب به انواع (Types) در تایپ اسکریپت خواهیم پرداخت.

997696

انواع در تایپ اسکریپت

1. انواع مقدماتی

در ادامه مثالی از یک نوع مقدماتی را می‌بینید:

این مثال کاربرد نوع‌ها را در تایپ اسکریپت به شکل زیر نشان می‌دهد:

در مورد نوع‌های ساده، در صورتی که انتساب متغیر در همان خط اعلان صورت بگیرد، می‌توان از نوشتن data_type خودداری کرد:

کامپایلر تایپ اسکریپت نوع متغیری را که به نام Type Inference شناخته می‌شود خود استنباط می‌کند و می‌توانیم از نوشتن کد غیرضروری اجتناب کنیم.

انواع مختلف متغیرهای مقدماتی در تایپ اسکریپت به شرح زیر هستند:

  1. بولی (درست یا نادرست)
  2. عدد (صحیح و اعشاری)
  3. رشته
  4. آرایه
  5. Any (می‌تواند هر نوع داده‌ای را شامل باشد)

در ادامه مثالی از هر یک از انواع فوق را مشاهده می‌کنید:

تعیین نوع داده می‌تواند بسیار مفید باشد، زیرا به یافتن خطاهای رایج مرتبط با انتساب کمک می‌کند.

هشدار: از کاربرد نوع any خودداری کنید، زیرا مانند این است که کد معمولی جاوا اسکریپت می‌نویسید.

در مثال فوق count از نوع any است که نوع پیش‌فرض مورد استفاده از سوی جاوا اسکریپت در زمان انتساب است. این اشتباه با استفاده از انواع زیر به راحتی قابل اجتناب است:

2. نوع تابع

در تایپ اسکریپت می‌توانیم انواعی برای تابع نیز تعریف کنیم. این وضعیت برای تعریف تابع callback که یک الگوی رایج در جاوا اسکریپت محسوب می‌شود کاملاً مفید است.

ابتدا باید یک تابع تعریف کنیم و به آن یک حاشیه‌نویسی نوع بدهیم:

در کد فوق ما نوع عددی را به متغیرهای num1 و num2 داده‌ایم و نوع بازگشتی تابع نیز پس از دونقطه آخر، به صورت عددی تعیین شده است. دقت کنید که در مورد تابع‌های arrow ساختار فوق متفاوت خواهد بود:

ممکن است متوجه شوید که کد فوق کمی سردرگم‌کننده است، بنابراین آن را به دو بخش تجزیه کرده و متغیرها را به جای const با let تعریف می‌کنیم:

در کد فوق یک متغیر به نام sum تعریف کرده‌ایم و نوع تابع به آن داده‌ایم که دو پارامتر از نوع number می‌گیرد و نوع بازگشتی نیز number است. سپس پیاده‌سازی تابع arrow را به آن انتساب می‌دهیم:

در کد فوق متغیر sum را با پیاده‌سازی تابع arrow انتساب می‌دهیم. یک نکته دیگر که باید اشاره کنیم این است که اگر تابع هیچ مقداری بازگشت ندهد، نوع بازگشتی آن void خواهد بود که به معنی عدم بازگشت نوع است.

در نهایت نوع تابع را با چند مثال کاربردی جمع‌بندی می‌کنیم:

3. چندتایی‌ها

اگر تاکنون کنجکاو شده‌اید که چگونه می‌توان بیش از یک مقدار را در تابع بازگشت داد، باید بگوییم که باید از چندتایی‌ها (Tuples) استفاده کنید که امکان بازگشت بیش از یک مقدار با نوع داده متفاوت را فراهم می‌سازد:

چندتایی‌ها در واقع در پس‌زمینه آرایه‌هایی هستند که تایپ اسکریپت آن‌ها را در یک نوع یکتا پوشش داده است تا بهبودهایی داشته باشند. چندتایی‌ها می‌توانند انواع داده‌های متفاوتی را کنار یکدیگر نگهداری کنند و با استفاده از اندیس‌ها همچون آرایه به آن‌ها دسترسی داشته باشید. اما چندتایی‌ها تفاوت‌هایی نیز با آرایه‌ها دارند. هر اندیس در چندتایی می‌تواند تنها یک نوع داده را نگهداری کند که در زمان اعلان چندتایی تعیین شده است. برخلاف زبان‌های دیگر برنامه‌نویسی، چندتایی‌ها در تایپ اسکریپت «تغییرپذیر» (mutable) هستند و می‌توان مقادیری را به چندتایی ارسال و از آن برداشت کرد.

همچنین می‌توان با دادن نوع داده خاص به یک اندیس، امکان تکمیل خودکار داشت که در آرایه‌ها وجود ندارد. گرچه چندتایی‌ها تغییرپذیر هستند، اما باید تا حد امکان از این کار اجتناب کرد. یکی از نمونه کاربردهای واقعی چندتایی‌ها در React جایی است که قلاب‌های ()useState چندتایی بازگشت می‌دهند.

4. انواع تهی‌پذیر

جاوا اسکریپت دو نوع undefined و null عرضه می‌کند که نماینده مقدار خالی یا مقدار تهی هستند و این وضعیت با زبان‌های جاوا و سی شارپ مشابهت دارد. این نوع داده همچنین یکی از رایج‌ترین خطاهای زمان اجرا است که در زمان برنامه‌نویسی در جاوا اسکریپت با آن مواجه می‌شویم. تایپ اسکریپت نیز این دو نوع را دارد و می‌توان آن‌ها را به هر نوع داده‌ای انتساب داد.

در کد فوق str مقدار undefined دارد، زیرا هرگز هیچ مقداری به آن انتساب نیافته است گرچه نوع داده آن رشته است. هر عملیاتی روی str موجب بروز خطای زمان اجرا می‌شود و از این رو باید با استفاده از گزاره if بررسی کنیم که آیا شامل مقداری است یا نه و سپس عملیات مورد نظر را انجام دهیم.

تایپ اسکریپت به صورت پیش‌فرض خطاهای زمان اجرای undefined و null را در زمان کامپایل در نظر نمی‌گیرد. یک فلگ به نام strictNullChecks وجود دارد که می‌توان در فایل tsconfig.json به صورت true تعیین کرد و موجب می‌شود که تایپ اسکریپت آنالیز گردش کد را برای کدهای نامطمئن با undefined و null انجام دهد و خطای مورد نظر را به جای زمان اجرا در زمان کامپایل ارائه کند.

زمانی که strictNullChecks به صورت true باشد، دستور let str: string;‎ خطایی ایجاد می‌کند، زیرا نمی‌توانیم undefined را به نوع رشته انتساب دهیم. برای این که بتوانیم undefined را به str انتساب دهیم، باید آن را به صورت زیر اعلان کنیم:

این یک نوع «تهی‌پذیر» (nullable) نامیده می‌شود. تایپ اسکریپت امکان دسترسی مستقیم به انواع تهی‌پذیر را به ما نمی‌دهد، اما در عوض می‌توانیم آن‌ها را مورد بررسی قرار دهیم.

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

نکته: null نمی‌تواند به let str: string|undefined انتساب یابد، زیرا null و undefined انواع متفاوتی در تایپ اسکریپت در نظر گرفته می‌شوند. برای این که بتوانیم null را انتساب دهیم باید متغیر را به صورت زیر تعریف کنیم:

بدین ترتیب می‌توان هر دو نوع undefined و null را به str انتساب داد. برخی اوقات هنگامی که می‌دانیم متغیر مفروض شامل undefined یا null نخواهد بود، می‌توانیم از type assertion برای حذف الزامی null استفاده کنیم:

در این کد علامت تعجب (!) برای حذف نوع تهی‌پذیر از str استفاده می‌شود و با آن length را فراخوانی می‌کند. type assertion باید با دقت و تنها در مواردی که اطمینان کامل دارید متغیر مفروض تهی‌پذیر نخواهد بود، مورد استفاده قرار گیرد.

5. انواع شمارشی

انواع شمارشی یا Enum-ها مانند ثابت‌هایی هستند که از نظر منطقی با هم دسته‌بندی شده‌اند تا به بهبود خوانایی ثابت‌ها از سوی انسان کمک کنند و کاربردهای مفید زیادی دارند. انواع شمارشی در زبان‌های دیگر مانند جاوا و سی شارپ نیز وجود دارند و از این نظر تفاوتی با انواع شمارشی در تایپ اسکریپت ندارند. انواع شمارشی به صورت زیر تعریف می‌شوند:

هر متغیر از نوع شمارشی می‌تواند تنها مقادیری که از سوی enum تعریف شده را داشته باشد به مثال زیر توجه کنید:

چنان که می‌بینید انواع شمارشی به ما امکان می‌دهند که قیود بیشتری بگذاریم و از نظر خوانایی انسانی بسیار بهتر از const هستند. انواع شمارشی به صورت پیش‌فرض مقادیر عددی که از 0 آغاز می‌شود می‌گیرند، اما می‌توانید به صورت دستی مقادیر دیگری نیز به آن‌ها بدهید.

همچنین می‌توانید مقادیر رشته‌ای به انواع شمارشی بدهید. توجه داشته باشید که انواع شمارشی تنها مقادیر عددی و رشته‌ای می‌توانند بگیرند.

6. اینترفیس‌ها

در جاوا اسکریپت غالباً اشیای زیادی به صورت درجا ساخته می‌شوند و در متغیر ذخیره شده و به تابعی ارسال می‌شوند. اینترفیس‌ها امکان تعریف ساختن این اشیا را به دست می‌دهند به طوری که می‌توانیم کدی را با این اطمینان بنویسیم که یک مشخصه خاص در آن شیء وجود دارد:

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

کامپایلر تایپ اسکریپت برابری ساختاری اینترفیس‌ها را بررسی می‌کند. در این حالت باید همه مشخصه‌های تعریف شده از سوی اینترفیس در شیء وجود داشته باشند، چون در غیر این صورت خطای زمان کامپایل تولید می‌شود. همچنین می‌توانیم اینترفیس بی‌نام تعریف کنیم:

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

اینترفیس‌ها به طور عمده به عنوان مدل مانند مدل‌های API برای پاسخ JSON استفاده می‌شوند. ایجاد مدل‌های اینترفیس به تکمیل خودکار از سوی IDE، بررسی خطا و همچنین به عنوان یک مستندسازی مستقل، کمک می‌کند.

سخن پایانی

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

اگر این مطلب برای شما مفید بوده است، آموزش‌های زیر نیز به شما پیشنهاد می‌شوند:

==

بر اساس رای ۲ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
mihir.jayavant02
دانلود PDF مقاله
نظر شما چیست؟

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