ساخت اپ های ماژولار جاوا اسکریپت – به زبان ساده

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

یکی از بزرگ‌ترین قابلیت‌های ES6، پشتیبانی جاوا اسکریپت از ماژول‌های داخلی است. ماژول‌ها به ما امکان می‌دهند که کد را بین فایل‌های مختلف با استفاده از ساختار export و import به اشتراک بگذاریم. این وضعیت بهبود بزرگی نسبت به استفاده از تگ‌های script و متغیرهای سراسری برای اشتراک کد بین فایل‌های مختلف محسوب می‌شود. در این مقاله در مورد روش استفاده از این قابلیت برای ساخت اپ های ماژولار جاوا اسکریپت صحبت می‌کنیم.

997696

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

اکسپورت و ایمپورت

برای این کد در یک فایل جاوا اسکریپت قابل ایمپورت باشد، باید آن‌ها را صراحتاً با گزاره export اکسپورت کنیم. به این منظور باید عبارت export را در ابتدای متغیر یا ثابتی که می‌خواهیم برای فایل‌های دیگر افشا شود قرار دهیم.

برای نمونه می‌توانیم کدی به صورت زیر بنویسیم:

کد فوق متغیر num را اکسپورت می‌کند، به طوری که ماژول‌های دیگر می‌توانند آن را import کرده و مورد استفاده قرار دهند. ما می‌توانیم هر چیزی را که با var ،let و const اعلان شده و همچنین تابع‌ها و کلاس‌ها را اکسپورت کنیم. آیتم‌هایی که اکسپورت می‌شوند، باید در سطح فوقانی اعلان شوند. گزاره export را نمی‌توان در جاهای دیگر مانند داخل تابع‌ها و کلاس‌ها استفاده کرد.

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

کد فوق به ما امکان می‌دهد که num1 ،num2 و num3 را در فایل‌های جاوا اسکریپت دیگر ایمپورت کنیم. اکنون که اعضا را اکسپورت کرده‌ایم، می‌توانیم آن‌ها را در فایل‌های جاوا اسکریپت دیگر ایمپورت کنیم. بدین منظور می‌توان از گزاره import برای ایمپورت یک یا چند عضو در یک ماژول و کار با آن‌ها استفاده کرد. برای نمونه اگر کد زیر را در moduleA.js داشته باشیم:

در ادامه در moduleB.js می‌توانیم کد زیر را برای ایمپورت کردن آیتم‌ها از moduleA.js استفاده کنیم:

مسیر پس از کلیدواژه from با یک نقطه آغاز می‌شود. معنی نقطه آن است که ما در پوشه جاری قرار داریم.

بدین ترتیب در کد فوق فرض شده است که moduleA.js و moduleB.js در پوشه یکسانی قرار دارند. اگر آن‌ها در پوشه متفاوتی باشند، در صورتی که بخواهیم اعضای moduleA.js را در moduleB.js ایمپورت و اکسپورت کنیم، باید مسیر moduleA.js را نسبت به moduleB.js بیان کنیم. برای نمونه اگر moduleA.js یک سطح بالاتر از moduleB.js باشد، در این صورت در moduleB.js می‌توانیم کدی مانند زیر بنویسیم:

2 نقطه پشت سر هم در جلوی مسیر به آن معنی است که باید یک سطح بالاتر برویم و سپس moduleAFolder و بعد از آن به moduleA.js برسیم.

می‌توانیم از ماژول‌های جاوا اسکریپت در تگ‌های script نیز استفاده کنیم. به این منظور باید خصوصیت type تگ script را به صورت module تعیین کنیم تا بتوانیم از آن‌ها استفاده کنیم. برای نمونه اگر بخواهیم از moduleA.js در فایل HTML خود استفاده کنیم، می‌توانیم کدی مانند زیر بنویسیم:

می‌توان از گزاره‌های import و export در ماژول‌های اسکریپت استفاده کرد. آن‌ها در اسکریپت‌های معمولی کار نمی‌کنند.

اسکریپت‌ها به صورت خودکار در حالت strict کار می‌کنند و از این رو نمی‌توانیم به صورت تصادفی متغیرهای سراسری اعلان کرده و کارهای دیگری که بدون فعال شدن حالت strict ممکن هستند را انجام دهیم. همچنین به صورت خودکار به صورت «ناهمگام» (asynchronous) بارگذاری می‌شوند به طوری که لازم نیست در مورد طولانی بودن اسکریپت‌ها و اخلال در بارگذاری صفحه نگران باشیم. ضمناً گزاره‌های import و export تنها بین 2 اسکریپت اتفاق می‌افتند و از این رو نیازی به تعیین متغیرهای سراسری نیست. بدین ترتیب نمی‌توان آن‌ها را مستقیماً در کنسول مشاهده کرد.

اکسپورت‌های پیش‌فرض

یک گزینه «اکسپورت پیش‌فرض» (default export) برای اکسپورت کردن اعضای ماژول وجود دارد.

ما پیش‌تر متغیر را به روشی اکسپورت کردیم که آن را بر اساس نام ایمپورت کنیم. یک default export نیز وجود دارد که یک عضو منفرد را از یک ماژول بدون نیاز به ارجاع صریح به نام آن در زمان ایمپورت شدن، اکسپورت می‌کند. برای نمونه اگر یک عضو منفرد در ماژول داشته باشیم که بخواهیم اکسپورت کنیم می‌توانیم کد زیرا در ماژول moduleA.js بنویسیم:

زمانی که از اکسپورت پیش‌فرض استفاده می‌کنیم، نیازی به آوردن آکولاد وجود ندارد. در ادامه در فایلی که می‌خواهیم عضو مربوطه را ایمپورت کنیم یعنی در ماژول moduleB.js کدی مانند زیر می‌نویسیم:

در این مورد نیز آکولاد نیامده است. دلیل این مسئله آن است که تنها یک اکسپورت پیش‌فرض در هر ماژول مجاز است. به طور جایگزین می‌توانیم کد زیر را در ماژول moduleB.js بنویسیم:

تغییر دادن نام ایمپورت و اکسپورت

اگر ماژول‌های زیادی داشته باشیم و اعضای اکسپورت‌شده آن‌ها نام یکسانی داشته باشند، در این صورت در زمان تلاش برای ایمپورت ماژول‌های مختلف با مشکل تداخل مواجه می‌شویم. این مسئله‌ای است که باید حل شود. خوشبختانه جاوا اسکریپت یک کلیدواژه به صورت as دارد که به اما امکان می‌دهد اکسپورت‌ها و ایمپورت‌ها را تغییر نام دهیم و به این ترتیب بتوانیم از تداخل نام‌ها در کد جلوگیری کنیم. برای استفاده از کلیدواژه as برای تغییر نام اکسپورت‌ها، می‌توانیم کدی مانند زیر در ماژول moduleA.js بنویسیم:

سپس در ماژول moduleB.js می‌توانیم آن‌ها را با نوشتن کد زیر ایمپورت کنیم:

به طور جایگزین می‌توانیم در زمان ایمپورت کردن نیز تغییر نام را انجام دهیم. به این منظور در ماژول moduleA.js کدی مانند زیر می‌نویسیم:

سپس در ماژول moduleB.js کد زیر را قرار می‌دهیم:

اگر تلاش کنیم که اعضا را از ماژول‌هایی که اعضای دارای نام یکسان دارند ایمپورت کنیم:

خواهیم دید که یک خطای SyntaxError ایجاد می‌شود. بنابراین باید نام آن‌ها را تغییر دهیم تا ماژول بتواند اجرا شود:

یک روش تمیزتر برای ایمپورت از چندین ماژول با اعضای دارای نام یکسان این است که همه اعضای اکسپورت شده ماژول را به صورت یک شیء ایمپورت کنیم. برای نمونه به جای نوشتن کدی مانند زیر:

می‌توانیم کدی مانند زیر بنویسیم:

سپس زیر ایمپورت‌ها، می‌توانیم کدی مانند زیر بنویسیم:

همچنین می‌توانیم کلاس‌ها را اکسپورت و ایمپورت کنیم. بنابراین اگر فایلی داشته باشیم که شامل یک یا چند کلاس مانند فایل Person.js با کلاس زیر باشد:

می‌توانیم با استفاده از کد زیر آن کلاس را اکسپورت کنیم:

کد فوق کلاس Person را اکسپورت می‌کند. برای ایمپورت کردن آن می‌توانیم کدی مانند زیر بنویسیم:

بارگذاری دینامیک ماژول

ماژول‌های جاوا اسکریپت می‌توانند به صورت دینامیک بارگذاری شوند. این وضعیت به ما امکان می‌دهد که ماژول‌ها را در زمانی که به آن‌ها نیاز داریم بارگذاری کنیم و دیگر لازم نیست همه ماژول‌ها را در زمان اجرای اپلیکیشن بارگذاری کنیم. به این منظور باید از تابع ()import استفاده کنیم که یک promise بازگشت می‌دهد. هنگامی که ماژول موجود در آرگومان بارگذاری می‌شود، promise کامل خواهد شد. promise به یک شیء ماژول resolve می‌شود که می‌توان از آن در کد اپلیکیشن استفاده کرد. اگر کلاس Person را در فایل Person.js داشته باشیم، در این صورت می‌توانیم آن را با کد زیر به صورت دینامیک ایمپورت کنیم:

همچنین می‌توانیم از ساختار async و await استفاده کنیم و به این منظور می‌توانیم آن‌ها را در یک تابع قرار دهیم:

چنان که می‌بینید، ماژول‌های جاوا اسکریپت برای سازماندهی کد بسیار مفید هستند. این وضعیت به ما امکان می‌دهد که همه مواردی که می‌خواهیم در ماژول‌های دیگر به آن‌ها دسترسی داشته باشیم را اکسپورت کنیم و به این ترتیب نیاز به استفاده از متغیرهای سراسری رفع می‌شود. به علاوه می‌توان نام اکسپورت‌ها و ایمپورت‌ها را تغییر داد تا از بروز تداخل در صورت ایمپورت از چندین ماژول اجتناب نمود. ضمناً همه اعضای اکسپورت شده را می‌توان به صورت یکجا ایمپورت کرد و به این ترتیب کل ماژول را به صورت یک شیء به دست آورد و دیگر نیازی به ایمپورت تک‌تک اعضا وجود ندارند. در نهایت می‌توانیم از export default تنها در صورتی که بخواهیم تنها یک عضو ماژول را اکسپورت کنیم، بهره بگیریم.

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

==

بر اساس رای ۱ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
gitconnected
دانلود PDF مقاله
۱ دیدگاه برای «ساخت اپ های ماژولار جاوا اسکریپت – به زبان ساده»

واقعا عالی توضیح داده بودین ،مفصل و لذت بخش

نظر شما چیست؟

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