ব্লেড টেমপ্লেট
লারাভেল এর সাথে ব্লেড টেমপ্লেট ইঞ্জিন বিল্ড ইন ভাবে এসেছে। আর এটা ব্যাবহার করা খুবই সহজ। ব্লেড টেমপ্লেটে কোড লেখার জন্য ভিউ ফাইলের এক্সটেনশন হতে হবে .blade.php ধরুন আপনার ভিউ ফাইলটির নাম about তাহলে ব্লেড এর ফরমেটে এটি হবে about.blade.php । এখন ব্লেড এর নিয়ম অনুসারে ভিউ পেজ গুলো সাজানোর জন্য একটা মাস্টার পেজ বানাতে হবে যেটাকে এক্সটেন্ড করে অন্য ভিউ গুলো বানাতে হবে। তাহলে আমরা যদি about এর জন্য একটি ভিউ বানাই ব্লেড এর নিয়ম অনুযায়ী, প্রথমে routeabout ডিফাইন করতে হবে তারপর মাস্টার পেজ বানাইতে হবে তারপর about পেজটি বানাইতে হবে। নিচে ধারাবাহিক ভাবে কোড গুলো দেখানো হল।
Route এর জন্য।
1
Route::get('/about', function(){
2
return view('about');
3
});
Copied!
মাস্টার পেজের জন্য।
1
<!-- Stored in resources/views/layouts/master.blade.php -->
2
3
<!DOCTYPE html>
4
<html lang="en">
5
<head>
6
<meta charset="utf-8">
7
<meta http-equiv="X-UA-Compatible" content="IE=edge">
8
<meta name="viewport" content="width=device-width, initial-scale=1">
9
<title>Laravel Project</title>
10
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css">
11
</head>
12
<body>
13
@yield('content')
14
@yield('footer')
15
</body>
16
</html>
Copied!
About পেজের জন্য।
1
<!-- Stored in resources/views/about.blade.php -->
2
3
@extends('master')
4
5
@section('content')
6
<div class="container">
7
<div class="row">
8
<div class="col-md-10">
9
<p>Your contents goes here</p>
10
</div>
11
</div>
12
</div>
13
@endsection
14
15
@section('footer')
16
<script src="{{ URL::asset('assets/js/myscript.js') }}"></script>
17
@stop
Copied!
এখন ধরুন আপনাকে বিশেষ ক্ষেত্রে কনটেন্ট সেকশন অথবা অন্য কোন সেকশনের জন্য ডিফল্ট কনটেন্ট/ডাটা রাখতে হচ্ছে তাহলে আপনাকে yield মেথডটিতে দ্বিতীয় প্যারামিটার পাস করে এটা করতে হবে।
1
@yield('section', 'Default Content')
Copied!
ব্লেডে ডাটা echo করার জন্য ডাবল কারলি ব্রাকেট ব্যাবহার করতে হয়।
1
Hello, {{ $name }}.
2
3
The current UNIX timestamp is {{ time() }}.
Copied!
এইক্ষেত্রে ভেরিয়েবল ডিফাইন করার জন্য ব্লেডের কমেন্টস ব্যাবহার করতে হবে নিচের মত করে।
1
@php
2
$name = 'Sohel Amin';
3
@endphp
4
5
Hello, {{ $name }}
Copied!
এবার ব্লেডে কন্ট্রোল স্ট্রাকচার সহ অন্যান্য ফিচার গুলো ধারাবাহিক ভাবে দেখানো হল।
If Statements এর জন্য নিচের পদ্ধ্যতি অনুসরন করুন।
1
@if (count($records) === 1)
2
I have one record!
3
@elseif (count($records) > 1)
4
I have multiple records!
5
@else
6
I don't have any records!
7
@endif
8
9
@unless (Auth::check())
10
You are not signed in.
11
@endunless
Copied!
Loops এর জন্য নিচের পদ্ধ্যতি অনুসরন করুন।
1
@for ($i = 0; $i < 10; $i++)
2
The current value is {{ $i }}
3
@endfor
4
5
@foreach ($users as $user)
6
<p>This is user {{ $user->id }}</p>
7
@endforeach
8
9
@forelse($users as $user)
10
<li>{{ $user->name }}</li>
11
@empty
12
<p>No users</p>
13
@endforelse
14
15
@while (true)
16
<p>I'm looping forever.</p>
17
@endwhile
Copied!
একটা ভিউ ফাইলে অন্য ভিউ ফাইল ইনক্লুড করার জন্য নিচের মত করে লিখতে হবে।
1
@include('view.name')
Copied!
আর আপনি চাইলে ভিউ ফাইল ইনক্লুড করার সমই ডাটা পাস করতে পারেন এইভাবে।
1
@include('view.name', ['some' => 'data'])
Copied!
কমেন্টস লিখতে চাইলে।
1
{{-- This comment will not be in the rendered HTML --}}
Copied!

ব্লেড টেমপ্লেটিংঃ HTML ও Forms

লারাভেল এর ব্লেড টেমপ্লেট ব্যবহার করে HTML ও Forms তৈরি করতে আমাদের একটি "Third party package" প্রয়োজন হবে। আসুন জেনে নেই কি ভাবে আমরা এই সুবিধা আমাদের প্রোজেক্ট এ আনতে পারি।
প্রোজেক্ট ডিরেক্টরি এর মুল পাথে composer.json নামে একটি ফাইল আছে যেটা আমাদের প্রোজেক্ট এর প্রয়োজনীয় প্যাকেজ গুলার তালিকা রাখে। ফাইলটির প্রথম কিছু অংশ অনেকটা এরকমঃ
1
{
2
"name": "laravel/laravel",
3
"description": "The Laravel Framework.",
4
"keywords": ["framework", "laravel"],
5
"license": "MIT",
6
"type": "project",
7
"require": {
8
"php": ">=5.6.4",
9
"laravel/framework": "5.3.*"
10
},
11
.
12
.
13
.
14
.
Copied!
ফাইলে "require" অংশে আমাদের প্রয়োজনীয় প্যাকেজটি যোগ করি, তাহলে এটা দেখতে হবে অনেকটাঃ
1
{
2
"name": "laravel/laravel",
3
"description": "The Laravel Framework.",
4
"keywords": ["framework", "laravel"],
5
"license": "MIT",
6
"type": "project",
7
"require": {
8
"php": ">=5.6.4",
9
"laravel/framework": "5.3.*",
10
"laravelcollective/html": "5.3.*"
11
},
12
.
13
.
14
.
15
.
Copied!
এবার "Composer" ব্যবহার করে এটাকে আমাদের প্রোজেক্ট এ যোগ করি নিচের command টি Terminal এ লিখে
1
composer update
Copied!
এটা আমাদের সব প্যাকেজ গুলোকে update, প্রয়োজনে add করে নিবে।
এবার config/app.php ফাইলটি খুলি, যেটা সব "provider" ও এর 'alias' এরে এর মধ্যে রাখে এবং অ্যাপ run করার সময় autoloader এর মাধ্যমে এগুলোকে load করে।
1
Collective\Html\HtmlServiceProvider::class,
Copied!
লাইনটি provider এরে এর শেষে যোগ করি।
1
'providers' => [
2
// ... previous providers classes
3
4
Collective\Html\HtmlServiceProvider::class,
5
6
],
Copied!
শেষ কাজ aliases এরে তে দুইটি class এর alias যোগ করা
1
'aliases' => [
2
// ... previous aliases
3
'Form' => Collective\Html\FormFacade::class,
4
'Html' => Collective\Html\HtmlFacade::class,
5
],
Copied!
আমরা প্রস্তুত ব্লেড টেমপ্লেট ব্যবহার করে HTML ও Forms তৈরি করত!!!!
উদাহরণ দেখার আগে একটি বিষয় জেনে নেই
1
{{ $data }}
Copied!
escaped value দেখাবে
1
{!! $data !!}
Copied!
unescaped value দেখাবে
একটু উদাহরণ দেই
1
$data = '<strong> How to Code BD </strong>'
2
{{ $data }}
Copied!
দেখাবেঃ <strong> How to Code BD </strong>
1
$data = '<strong> How to Code BD </strong>'
2
{!! $data !!}
Copied!
দেখাবেঃ How to Code BD
এইবার ফর্ম হেল্পার ব্যাবহার করে ফর্ম echo করার জন্য নিচের মত করে লিখতে হবে।
1
{!! Form::open(['url' => '#']) !!}
2
3
{!! Form::close() !!}
Copied!
এবং HTML আউটপুট হবে
1
<form accept-charset="UTF-8" action="#" method="POST">
2
<input type="hidden" value="hbyt7fA7MW09iT8V54z2V5u8j0mFFJJckSs7XI9G" name="_token">
3
4
</form>
Copied!
এখানে 'POST' মেথড দিবে যদি অন্য কোন মেথড আমরা উল্লেখ না করি। সাথে একটি html <input type="hidden" value="hbyt7fA7MW09iT8V54z2V5u8j0mFFJJckSs7XI9G" name="_token"> যা আমাদের সিকুইরিটি বাড়াবে।
এবার, নানা ধরনের input element গুলো আমাদের ফর্মে যোগ করিঃ
1
<div id="simple-form">
2
<h3>User Profile</h3>
3
<hr/>
4
{!! Form::open(array('url' => '#')) !!}
5
6
{!! Form::label('user_name', 'Name:') !!}
7
{!! Form::text('user_name') !!}
8
<br>
9
{!! Form::label('email', 'Email:') !!}
10
{!! Form::email('email', $value = null) !!}
11
<br>
12
{!! Form::label('gender', 'Gender:') !!}
13
{!! Form::radio('gender', 'Male', true) !!} Male
14
{!! Form::radio('gender', 'Female', false) !!} Female
15
{!! Form::radio('gender', 'Unisex', false) !!} Unisex
16
<br>
17
{!! Form::label('role', 'Role:') !!}
18
{!! Form::select('role', array(
19
'admin' => 'Administrator',
20
'author' => 'Author',
21
'subscriber' => 'Subscriber',
22
'registered' => 'registered'
23
24
)) !!}
25
<br>
26
{!! Form::label('about', 'About Me') !!}<br>
27
{!! Form::textarea('about') !!}
28
<br><br>
29
{!! Form::submit('Update') !!}
30
{!! Form::close() !!}
31
</div>
Copied!
ব্রাউজার দেখাবেঃ
HTML আউটপুট হবেঃ
1
<div id="simple-form">
2
<h3>User Profile</h3>
3
<hr>
4
<form accept-charset="UTF-8" action="#" method="POST"><input type="hidden" value="hbyt7fA7MW09iT8V54z2V5u8j0mFFJJckSs7XI9G" name="_token">
5
<label for="user_name">Name:</label>
6
<input type="text" id="user_name" name="user_name">
7
<br>
8
<label for="email">Email:</label>
9
<input type="email" id="email" name="email">
10
<br>
11
<label for="gender">Gender:</label>
12
<input type="radio" id="gender" value="Male" name="gender" checked="checked"> Male
13
<input type="radio" id="gender" value="Female" name="gender"> Female
14
<input type="radio" id="gender" value="Unisex" name="gender"> Unisex
15
<br>
16
<label for="role">Role:</label>
17
<select name="role" id="role">
18
<option value="admin">Administrator</option>
19
<option value="author">Author</option>
20
<option value="subscriber">Subscriber</option>
21
<option value="registered">registered</option>
22
</select>
23
<br>
24
<label for="about">About Me</label><br>
25
<textarea id="about" rows="10" cols="50" name="about"></textarea>
26
<br><br>
27
<input type="submit" value="Update">
28
</form>
29
</div>
Copied!
কিন্তু আমরা এই ফর্ম এর সাথে CSS দিবো, আমাদের id, class ও নানা ধরনের attribute ও যোগ করতে হবে। পূর্ববর্তী অনুশীলনে আমরা Twitter Bootstrap দিয়েছিলাম, এবার এই অনুশীলনে
    ভিউ তে blade ব্যবহার করে ভিউ আরও ব্যবহার যোগ্য করবো
    Form এর জন্য নতুন Template বানাবো, রাউট সেট করবো
    লারাভেল blade ও Twitter Bootstrap মিলিয়ে একটি Form তৈরি করবো
অনুশীলনঃ গত অধ্যায় এ আমরা ভিউ এবং এই অধ্যায় এ blade template দেখলাম। আসুন একটি master.blade.php ফাইল বানাই resources/views এর ভিতর।
1
<!doctype html>
2
<html lang="en">
3
<head>
4
<meta charset="UTF-8">
5
<title>@yield('title')</title>
6
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
7
</head>
8
<body>
9
<div class="container">
10
@yield('content')
11
</div>
12
13
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
14
</body>
15
</html>
Copied!
@yield('title')@yield('content') এর মানে title ও content নামে চাইল্ড টেমপ্লেটে কোনও section থাকলে এই অংশে দেখাবে। এটা আমারা একটি "Parent template" বানালাম।
এবার একটি "Child Template" বানাই উপরের blade template ব্যবহার করে যে Form টি বানিয়েছি সেটা নিয়ে। resources/views এর ভিতর pages নামে একটি ডাইরেক্টরি ও তার ভিতর form.blade.php নামে ফাইল তৈরি করি। এবং নিচের code গুলা লিখি।
1
@extends('master')
2
3
@section('title', 'Forms')
4
5
@section('content')
6
<div class="row">
7
<div class="col-md-6 col-md-offset-3">
8
<h3>User Profile</h3>
9
<hr/>
10
{!! Form::open(array('url' => '#')) !!}
11
12
{!! Form::label('user_name', 'Name:') !!}
13
{!! Form::text('user_name') !!}
14
<br>
15
{!! Form::label('email', 'Email:') !!}
16
{!! Form::email('email', $value = null) !!}
17
<br>
18
{!! Form::label('gender', 'Gender:') !!}
19
{!! Form::radio('gender', 'Male', true) !!} Male
20
{!! Form::radio('gender', 'Female', false) !!} Female
21
{!! Form::radio('gender', 'Unisex', false) !!} Unisex
22
<br>
23
{!! Form::label('role', 'Role:') !!}
24
{!! Form::select('role', array(
25
'admin' => 'Administrator',
26
'author' => 'Author',
27
'subscriber' => 'Subscriber',
28
'registered' => 'registered'
29
30
)) !!}
31
<br>
32
{!! Form::label('about', 'About Me') !!}<br>
33
{!! Form::textarea('about') !!}
34
<br><br>
35
{!! Form::submit('Update') !!}
36
{!! Form::close() !!}
37
</div>
38
</div>
39
@endsection
Copied!
তিনটি জিনিষ খেয়াল করার আছেঃ
@extends('master') মানে এই ফাইলটি views এর ভিতর যে master.blade.php আছে সেটি ব্যবহার করবে। @section('title', 'Forms') এটি section, প্রথম প্যারামিটারটি section এর নাম ও দ্বিতীয় প্যারামিটারটি section এর value. Valueটি যদি এমন একটি স্ট্রিং হয় তো এভাবেই লেখা যায়। কিন্তু দেখেন content নামের sectionটি শুধু প্রথম প্যারামিটারটি ব্যবহার করে নামটি দিয়েছে পরে এর বিশাল value দিয়েছে এবং অবশেষে @endsection লিখে sectionটি শেষ করেছে।
ফাইল তো হল, এদের জন্য রাউট তৈরি করি। routes/web.php ফাইলটি খুলে নিচের মত রাউট বানাই। আগের অনুশীলন গুলো করে থাকলে এটা আপনার জন্য খুবি সহজ।
1
Route::get('/form', function () {
2
return view('pages.forms');
3
});
Copied!
এখানে pages.forms লেখার কারণ pages ডাইরেক্টরি এর মধ্যে forms.blade.php ফাইলটি আছে। আর লারাভেল তো জানেই ভিউগুলা কোথায় থাকে।
আসুন এবার Twitter Bootstrap এর সাথে আমাদের HTML Blade মিক্সাপ করি।
আপনার forms.blade.php ফাইলটি আপডেট করুনঃ
1
<div class="col-md-6 col-md-offset-3">
2
<h3>User Profile</h3>
3
<hr/>
4
{!! Form::open(array('url' => '#', 'class'=>'form-horizontal')) !!}
5
<div class="form-group">
6
{!! Form::label('user_name', 'Name:') !!}
7
{!! Form::text('user_name', '', array('class' =>'form-control', 'placeholder'=>'User Name')) !!}
8
</div>
9
<div class="form-group">
10
{!! Form::label('email', 'Email:') !!}
11
{!! Form::email('email', $value = null, array('class' =>'form-control', 'placeholder'=>'Email Address')) !!}
12
</div>
13
<div class="form-group">
14
{!! Form::label('gender', 'Gender:') !!}
15
{!! Form::radio('gender', 'Male', true) !!} Male
16
{!! Form::radio('gender', 'Female', false) !!} Female
17
{!! Form::radio('gender', 'Unisex', false) !!} Unisex
18
</div>
19
<div class="form-group">
20
{!! Form::label('role', 'Role:') !!}
21
{!! Form::select('role', array(
22
'admin' => 'Administrator',
23
'author' => 'Author',
24
'subscriber' => 'Subscriber',
25
'registered' => 'registered'
26
),null, ['class' => 'form-control']) !!}
27
</div>
28
<div class="form-group">
29
{!! Form::label('about', 'About Me') !!}<br>
30
{!! Form::textarea('about','',array('class'=>'form-control', 'rows' => '4')) !!}
31
</div>
32
{!! Form::submit('Update Profile', array('class' => 'btn btn-primary')) !!}
33
{!! Form::close() !!}
34
</div>
Copied!
ব্রাউজার দেখাবেঃ
HTML আউটপুট হবেঃ
1
<form class="form-horizontal" accept-charset="UTF-8" action="#" method="POST"><input type="hidden" value="ZQ6nS9ifenMpro11inQ0azWGrnz5kRoi7lQ3UEdz" name="_token">
2
<div class="form-group">
3
<label for="user_name">Name:</label>
4
<input type="text" id="user_name" value="" name="user_name" placeholder="User Name" class="form-control">
5
</div>
6
<div class="form-group">
7
<label for="email">Email:</label>
8
<input type="email" id="email" name="email" placeholder="Email Address" class="form-control">
9
</div>
10
<div class="form-group">
11
<label for="gender">Gender:</label>
12
<input type="radio" id="gender" value="Male" name="gender" checked="checked"> Male
13
<input type="radio" id="gender" value="Female" name="gender"> Female
14
<input type="radio" id="gender" value="Unisex" name="gender"> Unisex
15
</div>
16
<div class="form-group">
17
<label for="role">Role:</label>
18
<select name="role" id="role" class="form-control"><option value="admin">Administrator</option><option value="author">Author</option><option value="subscriber">Subscriber</option><option value="registered">registered</option></select>
19
</div>
20
<div class="form-group">
21
<label for="about">About Me</label><br>
22
<textarea id="about" cols="50" name="about" rows="4" class="form-control"></textarea>
23
</div>
24
<input type="submit" value="Update Profile" class="btn btn-primary">
25
</form>
Copied!
কি লারাভেল Blade templating মজার না?
আজকে এই পর্যন্ত, এর পরের চ্যাপ্টারে কন্ট্রোলার সম্পর্কে আলোচনা করা হবে।
Last modified 3yr ago