ضمن عرض سلام و خسته نباشید خدمت تمامی همراهان روکسو. امیدوارم تا به اینجای کار مطالب لاراول مورد پسند شما قرار گرفته باشد. پس از بررسی کنترلرها که به عنوان قلب تپندهی هر وب سایت معرفی میشود، حال نوبت به ارائهی دومین کلید اصلی هر وب سایت یعنی Viewها است. ویو به عنوان یک نمایشگر کاملا حرفهای درنظر گرفته میشود که نیازهای کاربران به واسطهی آن به سرور ارسال و پاسخ مرتبط دریافت میشود. در این بخش به توضیح دقیق View می پردازیم.
اجازه بدهید در ابتدا به مبحث routing بازگردیم. اگر به خاطر ندارید اصلا نگران نباشید. routing همان مسیردهی و ساخت مسیر برای وب اپلیکیشن شما بود که در پوشهی routes قرار داشت حال برای اینکه مطالب این بخش را به دقت متوجه شوید نگاهی گذار به مقالهی زیر داشته باشید:
در واقع با استفاده از route ها متدهای HTTP را اجرا کرده و درخواست کاربران را به کنترلر ارسال و در نهایت پاسخی را که دریافت میکنیم در خروجی نمایش میدهیم. در این بخش میخواهم به نحوهی نمایش پاسخ درخواستها به کاربران، صحبت کنیم.
همانطور که در فصل ۲-۲ توضیح دادیم، فایلهای ویو در پوشهی resources/view قرار دارند. بنابراین برای شروع کار یک فایل با عنوان دلخواه مثلا home.blade.php ایجاد میکنیم. سپس محتویات درون فایل را برابر کدهای زیر قرار دهید:
<html> <head> <title>Roxo Application</title> </head> <body> <div class="container"> Hello World </div> </body> </html>
بسیار عالی تا به اینجای کار توانستیم یک ویو ایجاد کنیم. حال میخواهیم این ویو را به یک مسیر routing خاص متصل کنیم. یعنی میخواهیم وقتی کاربر آدرس مثلا http://www.roxo.ir/home را وارد کرد، به صفحهی مشخصی ارجاع داده شود.
برای تعریف یک routing مطابق با آموزش فصل ۳، ابتدا فایل web.php را از مسیر routes/web.php باز کرده با استفاده از یکی از روشهای زیر یک view ایجاد کرده و نام فایلی را که در مسیر resources/view ایجاد کردهایم به تابع یا متد view ارسال میکنیم:
// راه اول برای اضافه کردن ویو Route::get('/home', function(){ return view('home'); }); // راه دوم برای اضافه کردن ویو Route::get('/home', function(){ return View::make('home'); });
بسیار عالی! به شما تبریک میگوییم. در صورتیکه سرور لاراول خود را باز کنید و آدرس http://localhost/home رو بزنید (البته این آدرس برای هر پروژهای متفاوت خواهد بود) قطعا با صفحهی Hello World مواجعه خواهید شد. به همین سادگی شما توانستید یک ارتباط بین مسیر خود و در نهایت ویو خود ایجاد کنید. اگر بخواهید یک کنترلر خاص را به یک ویو خاص ارجاع دهید ابتدا باید در فایل خود دستوری مشابه دستور زیر را اعمال کنید:
public function home(){ return view('home'); }
سپس یک مسیردهی مشخص انجام دهید:
Route::get('/home', 'HomesController@home');
متد exist
از این متد زمانی استفاده میشود که بخواهیم وجود و یا عدم وجود یک صفحه ویو را بررسی کنیم و دستور آن به صورت زیر میباشد:
use Illuminate\Support\Facades\View; if (View::exists('emails.customer')) { // }
مهمترین قسمت هر کنترلر دادههاییست که به یک ویو ارسال و دریافت میکند. حال این سوال برای شما پیش میآید که منظور از دادههای موجود در کنترلر چیست؟ دادههایی که در کنترلر رد و بدل میشوند از طریق Model که با Database یا پایگاهداده در ارتباط است دریافت میشوند. برای روشنتر مبحث MVC در لاراول بهتر است مقالهی MVC زیر را مطالعه بفرمایید:
حال باید این دادهها به ویو جهت نمایش به کاربر، ارسال شوند. برای ارسال دادهها به ویو کافیست از آرگومان دوم تابع ()view استفاده کنیم. درنظر داریم که در این آرگومان میتوان دادهها به صورت رشته یا آرایه ارسال کرد:
// روش شماره ۱ public function home(){ return view('home', ['name' => 'Roxo.ir']); } // روش شماره ۲ public function home(){ $data = ['name' => 'Roxo.ir']; return view('home', $data); }
ممکن است این سوال برای شما پیش بیاید که عبارت name چیست؟ در پاسخ باید بگوییم که متغییر name دادهای است که مقدار Roxo.ir را با خود به ویو انتقال میدهد. بنابراین در این مثال در فایل home.blade.php هر جا عبارت {{ name$ }} دیده شود مقدار Roxo.ir در آن جایگزین میگردد. صفحه home.blade.php را به صورت زیر ویرایش کنید:
<html> <head> <title>Roxo Application</title> </head> <body> <div class="container"> Hello {{ $name }} </div> </body> </html>
گاهی میتوان دادههای موجود در یک کنترلر را در تمام viewها به اشتراک گذاشت. برای اینکار از متد share استفاده میکنیم:
View::share
جهت استفاده از این متد باید همواره دو مقدار variableName و variableValue را ارسال کنید:
View::share('variableName', 'variableValue');
حال شما با استفاده از دستورهای فوق میتوانید انواع صفحات را به کنترلرهای موردنظر خود لینک دهید. آموزش مبحث view به همین جا ختم نمیشود بلکه کار کردن با فرمها در ویو و همچنین نحوهی طراحی قالب در ویو با استفاده از موتور طراحی قالب Blade را در جلسات آینده به شما عزیزان آموزش خواهیم داد. امیدواریم این آموزش مورد پسند شما واقع شده باشد.
در این قسمت، به پرسشهای تخصصی شما دربارهی محتوای مقاله پاسخ داده نمیشود. سوالات خود را اینجا بپرسید.