Blade লারাভেলের টেম্পলেট ইঞ্জিন, যা HTML তৈরির জন্য ব্যবহৃত হয়। এটি ডাইনামিক কন্টেন্ট তৈরি করতে সাহায্য করে এবং কোড লেখার প্রক্রিয়াকে সহজ করে তোলে। নিচে Blade Templates-এর বিভিন্ন দিক ও উদাহরণসহ আলোচনা করা হলো।
Blade টেম্পলেট ইঞ্জিন লারাভেলের সাথে ডাইনামিক কন্টেন্ট তৈরি করতে ব্যবহৃত হয়। Blade-এর সাহায্যে কোড লেখার প্রক্রিয়া অনেক সহজ হয়।
ব্লেড হল লারাভেলের ডিফল্ট টেম্পলেট ইঞ্জিন। এটি HTML ডাইনামিকভাবে তৈরি করতে ব্যবহৃত হয় এবং এর কিছু প্রধান বৈশিষ্ট্য হল:
@if
, @foreach
, @extends
, ইত্যাদি ব্যবহার করে লজিকাল স্ট্রাকচার তৈরি করতে সহায়তা করে।Livewire একটি প্যাকেজ যা Blade টেম্পলেটগুলোর কার্যকারিতা বাড়ায়। উদাহরণস্বরূপ:
// Livewire Component
class Counter extends Component
{
public $count = 0;
public function increment()
{
$this->count++;
}
public function render()
{
return view('livewire.counter');
}
}
Blade টেম্পলেটে ব্যবহার:
{{ $count }}
Blade-এ ডেটা প্রদর্শন করতে {{ }}
সিম্বল ব্যবহার করুন:
{{ $title }}
যেখানে $title
হচ্ছে কন্ট্রোলার থেকে পাস করা ডেটা।
Blade স্বয়ংক্রিয়ভাবে ডেটা এনকোড করে, যা নিরাপত্তার জন্য গুরুত্বপূর্ণ। তবে, HTML রেন্ডার করতে চাইলে {!! !!}
ব্যবহার করুন:
{!! $htmlContent !!}
এখানে $htmlContent
একটি HTML স্ট্রিং।
Blade টেম্পলেটগুলি JavaScript ফ্রেমওয়ার্কের সাথে মিলে কাজ করতে পারে। উদাহরণস্বরূপ, Vue.js ব্যবহার করে:
এবং app.js
ফাইল:
new Vue({
el: '#app',
});
Blade ডিরেকটিভগুলি বিভিন্ন কার্যকলাপের জন্য ব্যবহৃত হয়। উদাহরণস্বরূপ:
@if ($user->isAdmin())
Welcome, Admin!
@endif
@switch($role)
@case('admin')
You are an admin.
@break
@case('user')
You are a user.
@break
@default
Guest
@endswitch
Blade-এ লুপ ব্যবহার করতে পারেন:
@foreach ($items as $item)
{{ $item }}
@endforeach
এখানে $items
হচ্ছে একটি অ্যারে।
লুপ চলাকালীন, @foreach
এর ভিতরে loop
ভেরিয়েবল ব্যবহার করে লুপের তথ্য পাওয়া যায়:
@foreach ($items as $item)
{{ $loop->iteration }}: {{ $item }}
@endforeach
শর্ত সাপেক্ষে ক্লাস যুক্ত করতে:
এখানে $isActive
একটি বুলিয়ান ভেরিয়েবল।
অতিরিক্ত অ্যাট্রিবিউট যোগ করতে:
এখানে $attributes
অ্যাসোসিয়েটিভ অ্যারে।
Subview অন্তর্ভুক্ত করতে @include
ব্যবহার করুন:
@include('partials.header')
এখানে partials.header
একটি Blade ভিউ ফাইল।
কোনো ব্লক কোড শুধুমাত্র একবার রেন্ডার করতে @once
ব্যবহার করুন:
@once
@endonce
Blade-এ কাঁচা PHP কোড ব্যবহার করতে পারেন:
Blade কমেন্ট যোগ করতে:
{{-- This is a comment --}}
ব্লেড কম্পোনেন্ট একটি পুনঃব্যবহারযোগ্য UI উপাদান তৈরি করতে সহায়তা করে। এটি কম্পোনেন্ট ভিত্তিক আর্কিটেকচার ব্যবহার করে, যা কোডের পুনঃব্যবহারযোগ্যতা এবং পরিষ্কারতা বৃদ্ধি করে।
বৈশিষ্ট্য:
{{ $message }}
ব্যবহার:
কম্পোনেন্ট রেন্ডার করতে:
কম্পোনেন্টে ডেটা পাঠাতে:
এখানে $type
এবং $message
হচ্ছে ভ্যারিয়েবল।
কম্পোনেন্ট অ্যাট্রিবিউটগুলি কাস্টমাইজ করতে:
Blade-এ কিছু রিজার্ভড কীওয়ার্ড রয়েছে, যেমন @if
, @foreach
, ইত্যাদি। এই কীওয়ার্ডগুলি ব্যবহার করতে পারেন, কিন্তু কাস্টম ডিরেক্টিভ তৈরি করতে গেলে এড়িয়ে চলা উচিত।
কম্পোনেন্টের জন্য স্লট ব্যবহার করা যায়, যা কাস্টম কন্টেন্টের জন্য উপযুক্ত।
Card Header
Card Body
ইনলাইন কম্পোনেন্ট ভিউ তৈরি করতে:
This is an alert!
ডাইনামিক কম্পোনেন্ট তৈরি করতে:
@component($componentName, ['data' => $data])
@endcomponent
এখানে $componentName
একটি ভ্যারিয়েবল যা কম্পোনেন্টের নাম ধারণ করে।
কম্পোনেন্টগুলি ম্যানুয়ালি রেজিস্টার করতে পারেন AppServiceProvider
এর boot
মেথডে:
Blade::component('alert', AlertComponent::class);
অ্যানোনিমাস কম্পোনেন্ট তৈরি করতে:
This is an alert!
অ্যানোনিমাস ইনডেক্স কম্পোনেন্ট ব্যবহার করতে:
কম্পোনেন্টে ডেটা প্রপার্টি অ্যাক্সেস করতে:
{{ $message }}
কম্পোনেন্টের প্যারেন্ট ডেটা অ্যাক্সেস করতে:
{{ $parentData }}
অ্যানোনিমাস কম্পোনেন্টের পাথ কাস্টমাইজ করা যায়।
লেনদেন নির্মাণের জন্য Blade-এ লেআউট তৈরি করা যায়। উদাহরণ:
My App
@yield('content')
এবং একটি ভিউ:
@extends('layouts.app')
@section('content')
Welcome to My App
@endsection
লেআউট তৈরিতে কম্পোনেন্ট ব্যবহার করতে:
// Content here
টেম্পলেট ইনহেরিটেন্স ব্যবহার করে লেআউট তৈরি করতে:
@extends('layouts.app')
@section('content')
// Content here
@endsection
ফর্ম তৈরি করতে:
CSRF ফিল্ড যোগ করতে:
@csrf
HTTP মেথড স্পেসিফাই করতে:
@method('PUT')
ভ্যালিডেশন এরর দেখানোর জন্য:
@if ($errors->any())
@foreach ($errors->all() as $error)
- {{ $error }}
@endforeach
@endif
স্ট্যাক ব্যবহার করতে:
@push('scripts')
@endpush
সার্ভিস ইনজেকশন করে Blade কম্পোনেন্টে যুক্ত করতে:
use App\Services\MyService;
class MyComponent extends Component
{
public function __construct(MyService $service)
{
// Use the service
}
}
ইনলাইন Blade টেমপ্লেট রেন্ডার করতে:
{!! view('inline.template', $data) !!}
Blade ফ্রাগমেন্ট রেন্ডার করতে:
{!! render('partials.fragment') !!}
Blade সম্প্রসারণ করতে নতুন ডিরেকটিভ তৈরি করতে পারেন:
Blade::directive('myDirective', function ($expression) {
return "";
});
কাস্টম ইকো হ্যান্ডলার তৈরি করতে:
Blade::directive('customEcho', function ($expression) {
return "";
});
কাস্টম If স্টেটমেন্ট তৈরি করতে:
Blade::if('active', function ($value) {
return $value == 'active';
});
লারাভেল ব্লেড এবং কম্পোনেন্টের মধ্যে মূল পার্থক্য হলো:
ব্লেড মূলত টেম্পলেট তৈরি করার জন্য ব্যবহৃত হয়, যেখানে কম্পোনেন্ট হলো ব্লেডের সাহায্যে তৈরি করা রিইউজেবল UI ইউনিট। ব্লেডে টেম্পলেটিং করা হয়, আর কম্পোনেন্টে UI লজিক ও স্টাইলিং অন্তর্ভুক্ত করা হয়।
Blade টেম্পলেট ইঞ্জিন লারাভেলের একটি শক্তিশালী অংশ, যা ডেভেলপারদের জন্য সহজ এবং কার্যকরী উপায়ে ডাইনামিক কন্টেন্ট তৈরি করতে সহায়তা করে। Blade এর বৈশিষ্ট্যগুলি ব্যবহার করে আপনি আপনার অ্যাপ্লিকেশনকে আরো ব্যবহারকারী-বান্ধব ও কার্যকরী করে তুলতে পারেন। Blade-এর উদাহরণগুলোকে কাজে লাগিয়ে ডেভেলপাররা দ্রুত এবং নিরাপদভাবে সাইট তৈরি করতে সক্ষম হন।
আরও দেখুন...