loading...
طراحی وب- برنامه نویسی
برنامه نویس بازدید : 57 چهارشنبه 09 مرداد 1398 نظرات (0)

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

مسیردهی (Routing) در انگولار چیست؟

هنگامیکه شما در حال تولید یک نرم‌افزار تک صفحه‌ای (Single Page App) هستید همواره نرم‌افزار خود را به سمتی سوق می‌دهید که کاربر با کلیک کردن روی لینک‌های مختلف بدون لود کردن و بارگذاری مجدد صفحه، بتواند به لینک موردنظر انتقال پیدا کند.

حال فرض کنید وب سایت یا نرم‌افزار شما دارای منوهایی است که کاربر با کلیک روی آنها به هر صفحه منتقل می‌شود و این انتقال در حالی انجام خواهد شد که رفرش یا بارگذاری مجددی صورت نمی‌گیرد. مثلا الان کاربر در آدرس http://www.roxo.ir قرار دارد و با کلیک روی لینک تماس با ما به صفحه http://www.roxo.ir/contact-us می‌رود. این مسیردهی به آدرس وب سایت را Routing می‌گویند.

حال انگولار امکانات و ابزاری را برای شما فراهم می‌کند که به سادگی بتوانید بدون بارگذاری مجدد صفحه، مسیردهی را انجام داده و کاربر را به هدف موردنظر خود منتقل کنید.

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

هدف از ارائه‌ی این مثال و کدها جلوگیری از کدنویسی اضافی و کوتاه کردن آموزش و در نهایت پرداختن به اصل موضوع مسیردهی (Routing) است. بنابراین اگر فایل پیوست شده را به درستی دانلود و روی سیستم خود اجرا کرده باشید با صفحه زیر روبه‌رو خواهید شد:

پروژه مدیریت سرور و مسیریابی در انگولار

حال مسیردهی (Routing) نرم‌افزار خود را انجام خواهیم داد.

تعریف مسیردهی (Routing) در انگولار

برای تعریف مسیردهی در نرم‌افزار خود ابتدا وارد فایل app.module.ts‌ شده و در ابتدای این صفحه یک ثابت به نام appRoutes ایجاد می‌کنیم تا تمام مسیردهی‌های نرم‌افزار خود را درون آن انجام دهیم. بنابراین داریم:

همانطور که مشخص است در ثابت appRoutes که از نوع کلاس Route‌ می‌باشد یک آرایه ایجاد (علت ایجاد آرایه برای دارا بودن چندین مسیر برای یک نرم‌افزار است) و سپس درون آن اشیاء جاوا اسکریپت را با علامت { } تولید کرده‌ایم.

اگر توجه داشته باشید درون این دو کروشه یک کلمه تحت عنوان path و دیگری با نام component وجود دارد:

کلمه‌کلیدی path: این کلمه برای نشان دادن مسیر صفحه می‌باشد. به عنوان مثال users به مسیر http://localhost:4200/users اشاره می‌کند.

کلمه‌کلیدی component: از این کلمه برای تعریف کامپوننت مرتبط با مسیر استفاده می‌شود به عنوان مثال کامپوننت مرتبط با مسیر http://localhost:4200/users معادل UsersComponent‌ است که لیست کاربران را نمایش می‌دهد.

بسیار عالی تا به اینجای کار مسیرها را تعریف کرده‌ایم ولی هنوز این مسیرها را به نرم‌افزار انگولاری معرفی نکرده‌ایم.

برای معرفی کردن باید از کلاس RouterModule استفاده کرده و با متد forRoot مسیر موردنظر را مشابه ذیل به نرم‌افزار معرفی کنیم:

همانطور که ملاحظه کردید تغییرات کلی در این فایل به صورت فوق اعمال شده است.

حال باید فایل app.component.html‌ را باز کنید و در نهایت به جای اسامی کامپوننت‌ها که به صورت تگ app-component‌ هستند یک ساختار جامع به نام router-outlet قرار دهیم تا به قالب HTML اطلاع دهیم که مسیرهای ما مشخص هستند و دیگر تمام کامپوننت‌ها را در یک صفحه لود نکن و متناسب با هر مسیری اطلاعات کامپوننت را نمایش بده! بنابراین در این فایل داریم:

با انجام این تغییر ملاحظه خواهید کرد که در صفحه نخست یعنی http://localhost:4200 تنها کامپوننت home فراخوانی می‌شود.

حال اگر در مرورگر خود آدرس http://localhost:4200/users را بزنید اطلاعات کامپوننت users و در نهایت با وارد کردن آدرس http://localhost:4200/servers اطلاعات کامپوننت servers را دریافت خواهید کرد.

بسیار عالی بنابراین خروجی تصویر ما به صورت زیر است:

اعمال router-outlet به قالب HTML

مسیریابی بین مسیرها (Navigation)

اگر مثال قبلی را بررسی کرده باشید وقتی روی زبانه‌های کاربران و سرور کلیک می‌کنیم اتفاقی نمی‌افتد. بنابراین باید به آنها مسیر مورد نظر را معرفی کنیم.

برای اینکار به جای استفاده از عبارت href از یک دستور به نام routerLink استفاده خواهیم کرد که عبارت روبه‌روی آن برابر مسیری‌ست که دوست داریم کاربر به آن بدون بارگذاری مجدد صفحه انتقال پیدا کند.

بنابراین فایل app.component.html را به صورت زیر ویرایش خواهیم کرد:

این سوال در حال حاضر برای شما به وجود آمده است که چرا مسیر سوم (کاربران) از طریق یک ویژگی بایند (ارسال) شده است؟

در پاسخ به این سوال باید خدمت شما عزیزان مطرح کنیم که این یکی دیگر از روش‌های ارسال کاربران صفحات مختلف است که در آن می‌توان آرگومان‌های متغییر به یک مسیر لحاظ کرد که بعدا به توضیح آن می‌پردازیم.

معرفی مسیرها در انگولار

برای نوشتن عبارت روبه‌روی routerLink چندین حالت مختلف می‌توان درنظر گرفت که مسیردهی شما را مشخص می‌کند در قسمت به صورت خلاصه نحوه‌ی نوشتاری مسیر رو برای شما عزیزان تشریح می‌کنیم.

مسیر مطلق: به مسیری گفته می‌شود که از روی ریشه‌ی آدرس خوانده می‌شود. به عنوان مثال اگر ریشه‌ی آدرس ما به صورت http://localhost:4200 باشد آنگاه مسیر زیر:

routerLink = “users”

یک مسیر مطلق نسبت به ریشه سایت (http://localhost:4200) است و با کلیک روی لینکی که این مسیردهی را انجام داده است، مسیر زیر را مشاهده خواهید کرد:

http://localhost:4200/users

مسیر نسبی: به مسیری گفته می‌شود که نسبت به مسیری که در آن قرار دارد آدرس دهی می‌شود. مثلا اگر مسیری که الان در آن قرار داریم به صورت http://localhost:4200/users باشد و بخواهیم صفت router-link را به صورت زیر تعریف کنیم:

router-link = "/profile"

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

http://localhost:4200/users/profile

مسیر نسبی با بازگشت: این مورد دقیقا مشابه حالت قبل است اما یک مرحله مسیر را به عقب باز می‌گرداند. بنابراین اگر مسیری که در آن قرار داریم به صورت http://localhost:4200 باشد و صفت router-link را به صورت زیر تعریف کرده باشیم:

router-link = "../profile"

آنگاه کاربر به آدرس زیر منتقل می‌شود:

http://localhost:4200/profile

زیرا ابتدا یک مرحله به عقب باز می‌گردد و در نهایت عبارت profile‌ را در مسیر قرار می‌دهد.

دستور routerLinkActive و routerLinkActiveOption

اگر فایل app.component.html‌ را بررسی بفرمایید متوجه خواهید شد که وقتی زبانه‌ی «صفحه اصلی» فعال است و ما روی صفحه‌ی «سرورها» یا «کاربران» کلیک می‌کنیم همچنان استایل زبانه‌ی «صفحه اصلی» فعال باقی مانده‌ است. بنابراین برای انتقال دادن استایل active به سایر زبانه‌ها از دستور routerLinkActive استفاده می‌کنیم. اما با اعمال این دستور نیز به هنگام انتقال به صفحات دیگر اگرچه استایل active بین آنها تغییر می‌کند اما «صفحه اصلی» همیشه به صورت ثابت این استایل را دارد زیرا همواره مسیریاب انگولار آن را به عنوان root می‌شناسد.

برای جلوگیری این ابهام از دستور routerLinkActiveOption استفاده می‌کنیم. بدین صورت که درون آن یک شیء از جاوا اسکریپت قرار داده و مقدار exact را برابر true قرار خواهیم داد.

این امر بدین معنی‌ست که دقیقا آدرس‌ مورد نظر را که تنها شامل اسلش (/) است به هنگامیکه روی آن قرار نگرفته‌ایم خالی از استایل کن! بنابراین برای اعمال این تغییرات در فایل app.component.html‌ داریم:

همینطور که ملاحظه می‌کنید با تغییر مسیر بین زبانه‌های مختلف استایل active مختص آن زبانه‌ فعال می‌شود.

گاهی نیاز داریم که در صفحه اصلی دکمه‌ یا لینکی قرار دهیم که با کلیک روی آن از طریق یک متد رویداد یا event به مسیر موردنظر انتقال پیدا کنیم. در این حالت باید از متد navigate و کلاس Router‌ استفاده کنیم.

بنابراین فایل home.component.html را باز کرده و درون آن یک دکمه به نام بارگذاری سرور قرار می‌دهیم:

حال برای تعریف متد onLoadServer فایل home.component.ts را باز کرده و سپس متد navigate از کلاس Router را مورد استفاده قرار می‌دهیم:

حال خروجی صفحه نمایش شما به صورت زیر خواهد بود و در صورت کلیک روی دکمه‌ی «بارگذاری سرور» وارد صفحه سرور می‌شوید.

اضافه کردن دکمه برای انتقال بین صفحات

حال فرض کنید می‌خواهیم یک دکمه در یکی از صفحات (مثلا صفحه «سرورها») قرار دهیم که با کلیک کردن روی آن صفحه مجددا بارگذاری شود. در این حالت می‌توانیم از یکی از قابلیت‌های دیگر فریم ورک انگولار به نام Route‌ استفاده کنیم.

فایل server.component.html‌ را باز کرده و تغییرات زیر را در آن لحاظ می‌کنیم:

سپس درون فایل server.component.ts‌ جهت معرفی متد onReloadServer اقدام کرده و در نهایت با استفاده از کلاس Router و ActivedRouter مسیر دهی روی این لینک را مشخص خواهیم کرد:

بسیار عالی! با استفاده از دستور relativeTo می‌توان به متد navigate اطلاع داد که مسیردهی به صورت نسبی از مسیر http://localhost:4200/servers انجام بگیرد.

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

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

دوره آموزش انگولار به زبان فارسی + پروژه ساخت فروشگاه اینترنتی

 

ارسال نظر برای این مطلب

کد امنیتی رفرش
اطلاعات کاربری
  • فراموشی رمز عبور؟
  • آرشیو
    آمار سایت
  • کل مطالب : 346
  • کل نظرات : 0
  • افراد آنلاین : 1
  • تعداد اعضا : 0
  • آی پی امروز : 16
  • آی پی دیروز : 17
  • بازدید امروز : 89
  • باردید دیروز : 21
  • گوگل امروز : 2
  • گوگل دیروز : 5
  • بازدید هفته : 163
  • بازدید ماه : 528
  • بازدید سال : 7,037
  • بازدید کلی : 35,272