فصل سه - Views
بخش سوم - کامپوننت ها - قسمت اول
کامپوننتها، ابزارهایی قدرتمند برای تسهیل توسعه رابط کاربری (UI) در برنامههای وب هستند. کامپوننتها به شما این امکان را میدهند که بخشهای کوچکی از رابط کاربری را به صورت مجزا ایجاد و مدیریت کنید، که این باعث میشود کدهای شما تمیزتر و قابل نگهداریتر باشند.
کامپوننتها قطعات قابل استفاده مجدد از کد هستند که شامل HTML و منطق لازم برای ایجاد بخشی از رابط کاربری میشوند. این کامپوننتها میتوانند دادهها را از والدین خود دریافت کنند و میتوانند به راحتی در بخشهای مختلف پروژه استفاده شوند.
کامپوننتها در لاراول معمولاً از دو بخش تشکیل میشوند:
1- بخش HTML:
که ساختار رابط کاربری را تعریف میکند.
2- بخش منطقی (Logic):
که میتواند شامل متدها و دادههایی باشد که برای تولید HTML مورد نیاز است. این بخش به طور معمول در کلاسهای PHP تعریف میشود.
کامپوننتها میتوانند به سادگی در فایلهای Blade فراخوانی شوند. برای مثال، اگر یک کامپوننت به نام alert دارید، میتوانید آن را به این صورت فراخوانی کنید:
این فراخوانی، کامپوننت مربوطه را به همراه دادههایی که به آن ارسال شده است، در صفحه نمایش میدهد.
لاراول دو نوع کامپوننت ارائه میدهد:
کامپوننتهای کلاس محور (Class-based Components) و کامپوننتهای بدون کلاس (Anonymous Components).
کامپوننتهای کلاس محور شامل یک فایل PHP کلاس برای مدیریت منطق هستند، در حالی که کامپوننتهای بدون کلاس تنها به یک فایل Blade برای نمایش متکی هستند و منطق پیچیدهای ندارند.
برای ساخت کامپوننت های کلاس محور میتوان از دستور زیر استفاده کرد:
این دستور یک کامپوننت با نام Alert ایجاد می کند که شامل یک کلاس در
برای ساخت کامپوننت های بدون کلاس یا ناشناس می توانید از دستور زیر استفاده کنید:
این دستور تنها یک فایل View در
همچنین می توانید کامپوننت ها را در فولدر های تو در تو ایجاد کنید:
همچنین برای فراخوانی کامپوننت از فولدر های خاص:
حال که کامپوننت خود را ایجاد کرده اید، کافی است کد های HTML خود را درون فایل View کامپوننت بنویسید و با فراخوانی کاپوننت آنها را نمایش دهید:
و برای فراخوانی آن:
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش سوم - کامپوننت ها - قسمت اول
کامپوننتها، ابزارهایی قدرتمند برای تسهیل توسعه رابط کاربری (UI) در برنامههای وب هستند. کامپوننتها به شما این امکان را میدهند که بخشهای کوچکی از رابط کاربری را به صورت مجزا ایجاد و مدیریت کنید، که این باعث میشود کدهای شما تمیزتر و قابل نگهداریتر باشند.
کامپوننتها قطعات قابل استفاده مجدد از کد هستند که شامل HTML و منطق لازم برای ایجاد بخشی از رابط کاربری میشوند. این کامپوننتها میتوانند دادهها را از والدین خود دریافت کنند و میتوانند به راحتی در بخشهای مختلف پروژه استفاده شوند.
کامپوننتها در لاراول معمولاً از دو بخش تشکیل میشوند:
1- بخش HTML:
که ساختار رابط کاربری را تعریف میکند.
2- بخش منطقی (Logic):
که میتواند شامل متدها و دادههایی باشد که برای تولید HTML مورد نیاز است. این بخش به طور معمول در کلاسهای PHP تعریف میشود.
کامپوننتها میتوانند به سادگی در فایلهای Blade فراخوانی شوند. برای مثال، اگر یک کامپوننت به نام alert دارید، میتوانید آن را به این صورت فراخوانی کنید:
<x-alert type="danger" :message="This is a danger alert" />
این فراخوانی، کامپوننت مربوطه را به همراه دادههایی که به آن ارسال شده است، در صفحه نمایش میدهد.
لاراول دو نوع کامپوننت ارائه میدهد:
کامپوننتهای کلاس محور (Class-based Components) و کامپوننتهای بدون کلاس (Anonymous Components).
کامپوننتهای کلاس محور شامل یک فایل PHP کلاس برای مدیریت منطق هستند، در حالی که کامپوننتهای بدون کلاس تنها به یک فایل Blade برای نمایش متکی هستند و منطق پیچیدهای ندارند.
برای ساخت کامپوننت های کلاس محور میتوان از دستور زیر استفاده کرد:
php artisan make:component Alert
این دستور یک کامپوننت با نام Alert ایجاد می کند که شامل یک کلاس در
app/View/Components
و یک فایل View در resources/views/components
می باشد.برای ساخت کامپوننت های بدون کلاس یا ناشناس می توانید از دستور زیر استفاده کنید:
php artisan make:component input --view
این دستور تنها یک فایل View در
resources/views/components
ایجاد می کند.همچنین می توانید کامپوننت ها را در فولدر های تو در تو ایجاد کنید:
# Class-based Components
php artisan make:component Forms/Input
# app/View/Components/Forms/Input.php
# resources/views/components/forms/input.blade.php
# Anonymous Components
php artisan make:component forms.input --view
# resources/views/components/forms/input.blade.php
همچنین برای فراخوانی کامپوننت از فولدر های خاص:
// from resources/views/components/forms
<x-forms.input />
حال که کامپوننت خود را ایجاد کرده اید، کافی است کد های HTML خود را درون فایل View کامپوننت بنویسید و با فراخوانی کاپوننت آنها را نمایش دهید:
// resources/views/components/alert.blade.php
<div class="alert alert-success">
This is an alert componnet!
</div>
و برای فراخوانی آن:
// Another View file in another world
<x-alert />
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
❤4🔥1
⚜️ دوره لاراول - قسمت ششم
📚 کنترلرها - بیس کنترلرها
خلاصه :
توی این ویدیو درمورد بیس کنترلرها یا همون کنترلرهای پایه ( ساده ) حرف زدیم.
در ویدیو بعدی به مبحث ادامه کنترلرها میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/hA1VSCIAJkw
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 کنترلرها - بیس کنترلرها
خلاصه :
توی این ویدیو درمورد بیس کنترلرها یا همون کنترلرهای پایه ( ساده ) حرف زدیم.
در ویدیو بعدی به مبحث ادامه کنترلرها میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/hA1VSCIAJkw
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
❤2🔥1
فصل سه - Views
بخش سوم - کامپوننت ها - قسمت دوم
ارسال دادهها و متغیرها به کامپوننتها برای پویا سازی آنها بسیار مهم است.
برای این کار کافی است درون فایل View کامپوننت خود متغییر ها را چاپ کنیم:
برای مقدار دهی متغیر های type و message در هنگام فراخوانی کامپوننت می توانید به صورت اتریبیوت های HTML پاس بدهیم:
در اینجا، مقادیر type و message به متغیرهای تعریفشده در کامپوننت ارسال میشوند و در نهایت، HTML تولید شده و در صفحه نمایش داده میشود.
در مثال بالا داده های استاتیک قابل ارسال است، برای ارسال متغیر باید به روش زیر عمل کنید:
علامت
متغیرهای $alertType و $alertMessage میتوانند از کنترلر یا جای دیگری در ویو شما باشند.
اگر از کامپوننت های کلاس محور استفاده می کنید می توانید این متغییر ها را درون کلاس نیز داشته باشید، کافی است متغیر ها را به صورت پراپرتی بنویسید و در کانستراکتور مقداردهی کنید:
در مثال بالا متغیر ها از طریق پراپرتی های تعریف شده در دسترس قرار دارند.
در حالت عادی تگ های کاپوننت ها نیاز به باز و بسته شدن ندارند، اما نیز می توانید آنها را باز و بسته کنید و میان آنها تگ ها یا داده های دیگری را بنویسید.
اسلات پیشفرض در واقع محتوا یا بخشی از HTML است که به طور مستقیم بین تگهای کامپوننت در ویو تعریف میشود و سپس در کامپوننت نمایش داده میشود.
محتوای بین تگ های کامپوننت از طریق متغیر $slot در فایل ویو در دسترس هستند.
در اینجا {{ $slot }} به عنوان اسلات پیشفرض عمل میکند. یعنی محتوایی که به این کامپوننت ارسال میشود، در جایگاه {{ $slot }} قرار میگیرد.
حالا میتوانید این کامپوننت را در یک ویو دیگر به این شکل استفاده کنید:
در این مثال، متن "This is a warning alert!" به عنوان اسلات پیشفرض در مکان {{ $slot }} قرار میگیرد و خروجی HTML به صورت زیر خواهد بود:
اسلاتهای نامگذاری شده به شما امکان میدهند که بخشهای مختلف یک کامپوننت را از طریق اسلاتهای مختلف پر کنید. این ویژگی زمانی مفید است که کامپوننت شما نیاز به دریافت چندین بخش محتوا داشته باشد.
در اینجا، {{ $header }} یک اسلات نامگذاری شده است و {{ $slot }} به عنوان اسلات پیشفرض برای محتوای اصلی استفاده میشود.
برای استفاده از این کامپوننت، شما میتوانید به این صورت عمل کنید:
در این مثال:
مقدار "Card Title" به عنوان محتوای اسلات نامگذاری شده header به کامپوننت ارسال میشود.
و مقدار "This is the card content." به عنوان محتوای پیشفرض درون اسلات پیشفرض ({{ $slot }}) قرار میگیرد.
نامگذاری متغیر های ورودی:
نام متغیر های درون کامپوننت باید به صورت cameCase نوشته شوند:
و نام اتریبیوت ورودی باید به صورت kebab-case نوشته شود:
درصورتی که نام متغیر درون کامپوننت با نام متغیری که باید به کامپوننت پاس داده شود برابر باشد می توانید آن را به صورت کوتاه شده بنویسید:
گاهی ممکن است ورودی های ما با دستورات Blade به تداخل بخورد، برای escape کردن آن تنها کافی است از دو عبارت
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش سوم - کامپوننت ها - قسمت دوم
ارسال دادهها و متغیرها به کامپوننتها برای پویا سازی آنها بسیار مهم است.
برای این کار کافی است درون فایل View کامپوننت خود متغییر ها را چاپ کنیم:
// resources/views/components/alert.blade.php
<div class="alert alert-{{ $type }}">
{{ $message }}
</div>
برای مقدار دهی متغیر های type و message در هنگام فراخوانی کامپوننت می توانید به صورت اتریبیوت های HTML پاس بدهیم:
<x-alert type="success" message="successful!" />
در اینجا، مقادیر type و message به متغیرهای تعریفشده در کامپوننت ارسال میشوند و در نهایت، HTML تولید شده و در صفحه نمایش داده میشود.
در مثال بالا داده های استاتیک قابل ارسال است، برای ارسال متغیر باید به روش زیر عمل کنید:
<x-alert :type="$alertType" :message="$alertMessage" />
علامت
:
قبل از نام متغیرها به این معناست که دادهها به عنوان متغیرهای PHP ارسال میشوند نه به عنوان رشته ثابت. متغیرهای $alertType و $alertMessage میتوانند از کنترلر یا جای دیگری در ویو شما باشند.
اگر از کامپوننت های کلاس محور استفاده می کنید می توانید این متغییر ها را درون کلاس نیز داشته باشید، کافی است متغیر ها را به صورت پراپرتی بنویسید و در کانستراکتور مقداردهی کنید:
namespace App\View\Components;
use Illuminate\View\Component;
class Alert extends Component
{
public $type;
public $message;
public function __construct($type, $message)
{
$this->type = $type;
$this->message = $message;
}
public function render()
{
return view('components.alert');
}
}
در مثال بالا متغیر ها از طریق پراپرتی های تعریف شده در دسترس قرار دارند.
در حالت عادی تگ های کاپوننت ها نیاز به باز و بسته شدن ندارند، اما نیز می توانید آنها را باز و بسته کنید و میان آنها تگ ها یا داده های دیگری را بنویسید.
اسلات پیشفرض در واقع محتوا یا بخشی از HTML است که به طور مستقیم بین تگهای کامپوننت در ویو تعریف میشود و سپس در کامپوننت نمایش داده میشود.
محتوای بین تگ های کامپوننت از طریق متغیر $slot در فایل ویو در دسترس هستند.
<div class="alert alert-{{ $type }}">
{{ $slot }}
</div>
در اینجا {{ $slot }} به عنوان اسلات پیشفرض عمل میکند. یعنی محتوایی که به این کامپوننت ارسال میشود، در جایگاه {{ $slot }} قرار میگیرد.
حالا میتوانید این کامپوننت را در یک ویو دیگر به این شکل استفاده کنید:
<x-alert type="warning">
This is a warning alert!
</x-alert>
در این مثال، متن "This is a warning alert!" به عنوان اسلات پیشفرض در مکان {{ $slot }} قرار میگیرد و خروجی HTML به صورت زیر خواهد بود:
<div class="alert alert-warning">
This is a warning alert!
</div>
اسلاتهای نامگذاری شده به شما امکان میدهند که بخشهای مختلف یک کامپوننت را از طریق اسلاتهای مختلف پر کنید. این ویژگی زمانی مفید است که کامپوننت شما نیاز به دریافت چندین بخش محتوا داشته باشد.
<div class="card">
<div class="card-header">
{{ $header }}
</div>
<div class="card-body">
{{ $slot }}
</div>
</div>
در اینجا، {{ $header }} یک اسلات نامگذاری شده است و {{ $slot }} به عنوان اسلات پیشفرض برای محتوای اصلی استفاده میشود.
برای استفاده از این کامپوننت، شما میتوانید به این صورت عمل کنید:
<x-card>
<x-slot:header>
Card Title
</x-slot>
This is the card content.
</x-card>
در این مثال:
مقدار "Card Title" به عنوان محتوای اسلات نامگذاری شده header به کامپوننت ارسال میشود.
و مقدار "This is the card content." به عنوان محتوای پیشفرض درون اسلات پیشفرض ({{ $slot }}) قرار میگیرد.
نامگذاری متغیر های ورودی:
نام متغیر های درون کامپوننت باید به صورت cameCase نوشته شوند:
<div class="alert alert-{{ $alertType }}">
{{ $slot }}
</div>
و نام اتریبیوت ورودی باید به صورت kebab-case نوشته شود:
<x-alert :alert-type="$alertType">
Alert
</x-alert>
درصورتی که نام متغیر درون کامپوننت با نام متغیری که باید به کامپوننت پاس داده شود برابر باشد می توانید آن را به صورت کوتاه شده بنویسید:
<x-alert :$alertType>
Alert
</x-alert>
گاهی ممکن است ورودی های ما با دستورات Blade به تداخل بخورد، برای escape کردن آن تنها کافی است از دو عبارت
::
استفاده کنید تا توسط Blade رندر نشوند:<x-button ::class="{ danger: isDeleting }">
Submit
</x-button>
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
👍3❤1🔥1
فصل سه - Views
بخش سوم - کامپوننت ها - قسمت سوم
ویژگی
این ویژگی شامل متدهای متعددی برای کار با اتریبیوت ها میشود.
1- متد merge:
این متد به شما اجازه میدهد که ویژگیهای جدیدی را به مجموعه ویژگیهای موجود اضافه کنید و در صورت وجود ویژگیهای تکراری، آنها را ادغام کنید. معمولاً برای کلاسهای CSS استفاده میشود.
اگر کلاسهای CSS به این کامپوننت پاس داده شوند، merge آنها را با کلاسهای پیشفرض ترکیب میکند. برای مثال:
کلاس نهایی ترکیب شده به صورت alert alert-success my-custom-class خواهد بود.
2- متد class:
این متد به طور خاص برای کار با کلاسهای CSS استفاده میشود. شما میتوانید کلاسهای جدیدی اضافه کنید یا کلاسهای موجود را با شرطهایی مدیریت کنید.
اگر $isBold مقدار true داشته باشد، کلاس font-bold اضافه میشود.
3- متد prepend:
این متد برای افزودن ویژگیهای جدید به ابتدا (اولویت) مجموعه ویژگیهای موجود استفاده میشود. اگر ویژگی مورد نظر قبلاً موجود باشد، مقدار جدید در ابتدا اضافه میشود.
اگر کامپوننت قبلاً دارای کلاس font-bold نباشد، به ابتدای لیست کلاسها اضافه میشود.
4- متد filter:
این متد به شما اجازه میدهد که ویژگیها را بر اساس یک شرط فیلتر کنید.
در این مثال، فقط ویژگیهای class و id نگه داشته میشوند و سایر ویژگیها فیلتر میشوند.
5- متد whereStartsWith:
این متد ویژگیهایی را که کلید آنها با رشته خاصی شروع میشود، فیلتر میکند.
این کد تمام ویژگیهایی که با data- شروع میشوند را به div اضافه میکند.
6- متد whereDoesntStartWith:
این متد ویژگیهایی که کلید آنها با رشته خاصی شروع نمیشود را فیلتر میکند.
این کد تمام ویژگیهایی که با wire: شروع نمیشوند را نگه میدارد.
7- متد has:
این متد بررسی میکند که آیا یک ویژگی خاص در مجموعه ویژگیها وجود دارد یا خیر.
این کد بررسی میکند که آیا ویژگی class وجود دارد و در صورت عدم وجود، یک کلاس پیشفرض استفاده میکند.
8- متد hasAny:
این متد بررسی میکند که آیا هر یک از ویژگیهای مورد نظر در مجموعه وجود دارند یا خیر.
این کد بررسی میکند که آیا یکی از ویژگیهای class یا id وجود دارند و در صورت وجود، div را با آنها رندر میکند.
9- متد get:
این متد مقدار یک ویژگی خاص را برمیگرداند. اگر ویژگی وجود نداشته باشد، میتوانید یک مقدار پیشفرض برای آن تعیین کنید.
در اینجا، اگر ویژگی id پاس داده نشده باشد، مقدار پیشفرض default-id استفاده میشود.
این متدها به شما اجازه میدهند که به شکلی انعطافپذیر با ویژگیهای HTML که به کامپوننتهای Blade لاراول پاس داده میشوند، کار کنید. با استفاده از این متدها، میتوانید ویژگیها را فیلتر کنید، ادغام کنید، بررسی کنید که آیا ویژگیای وجود دارد یا خیر، و در نهایت به شکل دقیقتری کامپوننتهای خود را مدیریت کنید.
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش سوم - کامپوننت ها - قسمت سوم
ویژگی
$attributes
به طور خودکار تمامی ویژگیهای اضافیای که به یک کامپوننت Blade پاس داده میشوند را مدیریت میکند. این ویژگی شامل متدهای متعددی برای کار با اتریبیوت ها میشود.
1- متد merge:
این متد به شما اجازه میدهد که ویژگیهای جدیدی را به مجموعه ویژگیهای موجود اضافه کنید و در صورت وجود ویژگیهای تکراری، آنها را ادغام کنید. معمولاً برای کلاسهای CSS استفاده میشود.
<div {{ $attributes->merge(['class' => 'alert alert-' . $type]) }}>
{{ $slot }}
</div>
اگر کلاسهای CSS به این کامپوننت پاس داده شوند، merge آنها را با کلاسهای پیشفرض ترکیب میکند. برای مثال:
<x-alert type="success" class="my-custom-class">
Success!
</x-alert>
کلاس نهایی ترکیب شده به صورت alert alert-success my-custom-class خواهد بود.
2- متد class:
این متد به طور خاص برای کار با کلاسهای CSS استفاده میشود. شما میتوانید کلاسهای جدیدی اضافه کنید یا کلاسهای موجود را با شرطهایی مدیریت کنید.
<div {{ $attributes->class(['alert', 'alert-' . $type, 'font-bold' => $isBold]) }}>
{{ $slot }}
</div>
اگر $isBold مقدار true داشته باشد، کلاس font-bold اضافه میشود.
3- متد prepend:
این متد برای افزودن ویژگیهای جدید به ابتدا (اولویت) مجموعه ویژگیهای موجود استفاده میشود. اگر ویژگی مورد نظر قبلاً موجود باشد، مقدار جدید در ابتدا اضافه میشود.
<div {{ $attributes->prepend('class', 'font-bold') }}>
{{ $slot }}
</div>
اگر کامپوننت قبلاً دارای کلاس font-bold نباشد، به ابتدای لیست کلاسها اضافه میشود.
4- متد filter:
این متد به شما اجازه میدهد که ویژگیها را بر اساس یک شرط فیلتر کنید.
<div {{ $attributes->filter(fn ($value, $key) => $key === 'class' || $key === 'id') }}>
{{ $slot }}
</div>
در این مثال، فقط ویژگیهای class و id نگه داشته میشوند و سایر ویژگیها فیلتر میشوند.
5- متد whereStartsWith:
این متد ویژگیهایی را که کلید آنها با رشته خاصی شروع میشود، فیلتر میکند.
<div {{ $attributes->whereStartsWith('data-') }}>
{{ $slot }}
</div>
این کد تمام ویژگیهایی که با data- شروع میشوند را به div اضافه میکند.
6- متد whereDoesntStartWith:
این متد ویژگیهایی که کلید آنها با رشته خاصی شروع نمیشود را فیلتر میکند.
<div {{ $attributes->whereDoesntStartWith('wire:') }}>
{{ $slot }}
</div>
این کد تمام ویژگیهایی که با wire: شروع نمیشوند را نگه میدارد.
7- متد has:
این متد بررسی میکند که آیا یک ویژگی خاص در مجموعه ویژگیها وجود دارد یا خیر.
@if ($attributes->has('class'))
<div {{ $attributes }}>
{{ $slot }}
</div>
@else
<div class="default-class">
{{ $slot }}
</div>
@endif
این کد بررسی میکند که آیا ویژگی class وجود دارد و در صورت عدم وجود، یک کلاس پیشفرض استفاده میکند.
8- متد hasAny:
این متد بررسی میکند که آیا هر یک از ویژگیهای مورد نظر در مجموعه وجود دارند یا خیر.
@if ($attributes->hasAny(['class', 'id']))
<div {{ $attributes }}>
{{ $slot }}
</div>
@endif
این کد بررسی میکند که آیا یکی از ویژگیهای class یا id وجود دارند و در صورت وجود، div را با آنها رندر میکند.
9- متد get:
این متد مقدار یک ویژگی خاص را برمیگرداند. اگر ویژگی وجود نداشته باشد، میتوانید یک مقدار پیشفرض برای آن تعیین کنید.
<div id="{{ $attributes->get('id', 'default-id') }}">
{{ $slot }}
</div>
در اینجا، اگر ویژگی id پاس داده نشده باشد، مقدار پیشفرض default-id استفاده میشود.
این متدها به شما اجازه میدهند که به شکلی انعطافپذیر با ویژگیهای HTML که به کامپوننتهای Blade لاراول پاس داده میشوند، کار کنید. با استفاده از این متدها، میتوانید ویژگیها را فیلتر کنید، ادغام کنید، بررسی کنید که آیا ویژگیای وجود دارد یا خیر، و در نهایت به شکل دقیقتری کامپوننتهای خود را مدیریت کنید.
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
❤4👍1🔥1
فصل سه - Views
بخش سوم - کامپوننت ها - قسمت چهارم
درصورتی که یک پکیج توسعه می دهید که شامل چندین کامپوننت می باشد، می توانید به صورت زیر آن را در پروژه ها لود کنید:
ابتدا در یک پروایدر مانند App\Providers\AppServiceProvider.php درون متد boot یک نیم اسپیس را به پکیج خود اختصاص می دهید:
در مثال بالا nightshade برابر با نیم اسپیس داده شده می باشد.
و سپس برای استفاده:
کامپوننت calendar از نیم اسپیس nightshade که در پروایدر تعریف کرده ایم فراخوانی خواهد شد.
متد های داینامیک:
علاوه بر داینامیک بودن متغیر ها در views، متد ها نیز قابل استفاده هستند:
شما میتوانید درون کلاس کامپوننت خود یک متد را تعریف کنید و به صورت invoke درون view استفاده کنید:
برای استفاده:
کامپوننت های خطی یا inline:
درصورتی که یک کامپوننت خیلی کوچک نیاز دارید میتوانید با دستور زیر یک کاپوننت اینلاین ایجاد کنید.
این کامپوننت ها تنها از یک کلاس تشکیل شده اند و فایل view ندارند.
کافی است درون متد render کد های HTML خود را قرار دهید:
دستورات Blade سفارسی:
گاهی نیاز است دستورات Blade خود را پیاده سازی کنیم، در ادامه به متد های آن می پردازیم.
تمامی متد ها از فساد Blade قابل دسترس هستند.
1- متد directive:
این متد برای تعریف یک دایرکتیو سفارشی استفاده میشود. شما میتوانید یک دایرکتیو سفارشی با نام دلخواه خود ایجاد کنید که در قالبهای Blade قابل استفاده باشد.
برای استفاده:
2- متد if:
این متد برای ایجاد دایرکتیوهای شرطی (conditional directives) استفاده میشود. این دایرکتیوها به شما امکان میدهند تا شرطهای پیچیده را به صورت خواناتر و سادهتر در قالبهای Blade بنویسید.
برای استفاده:
3- متد component:
این متد به شما امکان میدهد تا یک کامپوننت کلاس Blade یا یک ویوی Blade را به یک دایرکتیو خاص متصل کنید.
برای استفاده:
4- متد include:
این متد برای تعریف یک دایرکتیو سفارشی که یک ویوی خاص را شامل میشود، استفاده میشود. این روش بسیار مشابه استفاده از @include است اما با دایرکتیو خاص خودتان.
برای استفاده:
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش سوم - کامپوننت ها - قسمت چهارم
درصورتی که یک پکیج توسعه می دهید که شامل چندین کامپوننت می باشد، می توانید به صورت زیر آن را در پروژه ها لود کنید:
ابتدا در یک پروایدر مانند App\Providers\AppServiceProvider.php درون متد boot یک نیم اسپیس را به پکیج خود اختصاص می دهید:
public function boot(): void
{
Blade::componentNamespace('Nightshade\\Views\\Components', 'nightshade');
}
در مثال بالا nightshade برابر با نیم اسپیس داده شده می باشد.
و سپس برای استفاده:
<x-nightshade::calendar />
کامپوننت calendar از نیم اسپیس nightshade که در پروایدر تعریف کرده ایم فراخوانی خواهد شد.
متد های داینامیک:
علاوه بر داینامیک بودن متغیر ها در views، متد ها نیز قابل استفاده هستند:
شما میتوانید درون کلاس کامپوننت خود یک متد را تعریف کنید و به صورت invoke درون view استفاده کنید:
public function isSelected(string $option): bool
{
return $option === $this->selected;
}
برای استفاده:
<option {{ $isSelected($value) ? 'selected' : '' }} value="{{ $value }}">
{{ $label }}
</option>
کامپوننت های خطی یا inline:
درصورتی که یک کامپوننت خیلی کوچک نیاز دارید میتوانید با دستور زیر یک کاپوننت اینلاین ایجاد کنید.
php artisan make:component Alert --inline
این کامپوننت ها تنها از یک کلاس تشکیل شده اند و فایل view ندارند.
کافی است درون متد render کد های HTML خود را قرار دهید:
public function render(): View|Closure|string
{
return <<<'blade'
<div>
</div>
blade;
}
دستورات Blade سفارسی:
گاهی نیاز است دستورات Blade خود را پیاده سازی کنیم، در ادامه به متد های آن می پردازیم.
تمامی متد ها از فساد Blade قابل دسترس هستند.
1- متد directive:
این متد برای تعریف یک دایرکتیو سفارشی استفاده میشود. شما میتوانید یک دایرکتیو سفارشی با نام دلخواه خود ایجاد کنید که در قالبهای Blade قابل استفاده باشد.
Blade::directive('datetime', function ($expression) {
return "<?php echo ($expression)->format('m/d/Y H:i'); ?>";
});
برای استفاده:
@datetime($post->created_at)
2- متد if:
این متد برای ایجاد دایرکتیوهای شرطی (conditional directives) استفاده میشود. این دایرکتیوها به شما امکان میدهند تا شرطهای پیچیده را به صورت خواناتر و سادهتر در قالبهای Blade بنویسید.
use Illuminate\Support\Facades\Blade;
Blade::if('admin', function () {
return isAdmin(); // isAdmin() not a valid function
});
برای استفاده:
@admin
<p>You are an admin.</p>
@else
<p>You are not an admin.</p>
@endadmin
3- متد component:
این متد به شما امکان میدهد تا یک کامپوننت کلاس Blade یا یک ویوی Blade را به یک دایرکتیو خاص متصل کنید.
Blade::component('alert', 'components.alert');
برای استفاده:
@alert(['type' => 'danger'])
This is a warning alert!
@endalert
4- متد include:
این متد برای تعریف یک دایرکتیو سفارشی که یک ویوی خاص را شامل میشود، استفاده میشود. این روش بسیار مشابه استفاده از @include است اما با دایرکتیو خاص خودتان.
Blade::include('components.alert', 'alert');
برای استفاده:
@alert(['type' => 'danger'])
This is a warning alert!
@endalert
🔖 #Laravel, #PHP, #لاراول, #فصل_۳
👤 AmirHossein
💎 Channel: @DevelopixLaravel
👍3🔥3❤2
فصل چهار - مدلها و Eloquent ORM
بخش اول - معرفی Eloquent
الوکوئنت (Eloquent) یکی از بخشهای مهم و قدرتمند فریمورک لاراول است که به عنوان ORM (Object-Relational Mapping) عمل میکند. ORM یک تکنیک برنامهنویسی است که به توسعهدهندگان اجازه میدهد تا با پایگاه داده به صورت شیءگرا کار کنند و جداول پایگاه داده را به کلاسهای PHP تبدیل کنند.
کارکرد اصلی الوکوئنت:
الکوئنت به شما امکان میدهد تا با استفاده از مدلهای شیءگرا (Objects)، دادههای پایگاه داده را دستکاری کنید. این به شما اجازه میدهد که به جای نوشتن کوئریهای SQL خام، از متدهای شیءگرای الوکوئنت استفاده کنید که کد را تمیزتر و قابلفهمتر میکند.
ویژگیها و قابلیتهای الوکوئنت:
1- تعریف مدلها: در الوکوئنت، هر جدول پایگاه داده با یک مدل مطابقت دارد. این مدلها کلاسهایی هستند که رفتارها و ویژگیهای مرتبط با جداول پایگاه داده را مشخص میکنند. همچنین یکی از سه بخش معماری MVC را تشکیل می دهند.
2- روابط: الوکوئنت به شما امکان میدهد تا روابط بین جداول را به راحتی تعریف کنید. برای مثال:
ارتباط یک به یک (One to One).
ارتباط یک به چند (One to Many).
ارتباط چند به چند (Many to Many).
ارتباطات چندشکلی که یک مدل میتواند با چندین مدل دیگر مرتبط باشد (Polymorphic).
3- اسکوپهای عمومی و محلی: میتوانید کوئریهای عمومی که به صورت مکرر استفاده میشوند را در مدل تعریف کنید (Global Scopes) یا متدهایی ایجاد کنید که اسکوپهای محلی را تعریف کنند (Local Scopes).
4- پیمایشگرها و دسترسیگرها (Mutators and Accessors): به شما اجازه میدهد تا رفتارهای خاصی را هنگام تنظیم یا گرفتن ویژگیهای یک مدل اعمال کنید.
5- رخدادها (Events): الوکوئنت دارای سیستم رخدادهایی است که شما میتوانید به آنها گوش دهید و به ازای رویدادهایی مانند creating, updating, deleting و غیره واکنش نشان دهید.
6- کوئریسازی شیءگرا (Object-Oriented Querying): الکوئنت به شما اجازه میدهد تا به جای استفاده از SQL خام، از متدهای شیءگرا برای ایجاد کوئریها استفاده کنید. این کوئریها شامل فیلتر کردن، مرتبسازی، گروهبندی و سایر عملیاتهای پیچیده میشود، بدون اینکه نیازی به نوشتن یک خط SQL باشد.
7- مهاجرتها (Migrations) و بذرها (Seeders): در کنار مدلهای الوکوئنت، لاراول ابزارهایی برای مدیریت ساختار پایگاه داده (مهاجرتها) و پر کردن جداول با دادههای نمونه (سیدر و فکتوری) فراهم میکند. این ابزارها به توسعهدهندگان کمک میکنند تا بهراحتی پایگاه دادههای خود را ایجاد و مدیریت کنند.
8- پشتیبانی از Eager Loading و Lazy Loading: الکوئنت از دو روش برای بارگذاری دادههای مرتبط با مدلها پشتیبانی میکند:
بارگذاری (Eager): این روش به شما امکان میدهد دادههای مرتبط با یک مدل را همزمان با فراخوانی مدل بارگذاری کنید تا از تعداد کوئریهای اضافی جلوگیری شود.
بارگذاری (Lazy): این روش زمانی دادههای مرتبط را بارگذاری میکند که به آنها نیاز داشته باشید. این ممکن است منجر به ارسال کوئریهای اضافی به پایگاه داده شود.
9- پشتیبانی از Soft Deletes: الکوئنت امکان (Soft Delete) را فراهم میکند که به جای حذف دائمی یک رکورد، آن را "پنهان" میکند تا بعداً بتوان آن را بازیابی کرد. این کار از طریق یک فیلد اضافی در جدول انجام میشود که تاریخ و زمان حذف را ثبت میکند.
10- و...
مزایا و کاربردهای عملی:
استفاده از الوکوئنت باعث میشود که کدها به مراتب خواناتر و قابل نگهداریتر باشند.
نیاز به نوشتن کوئریهای SQL به حداقل میرسد و توسعهدهنده میتواند روی منطق برنامه تمرکز کند.
الوکوئنت با ارائه ابزارهایی برای مدیریت روابط بین جداول، پیچیدگی مدیریت این روابط را به طور چشمگیری کاهش میدهد.
الوکوئنت برای توسعهدهندگانی که از لاراول برای ساخت برنامههای وب استفاده میکنند، ابزاری ضروری است. این ابزار در تمامی جنبههای کار با پایگاه داده از جمله تعریف مدلها، روابط، کوئریسازی و حتی مدیریت مهاجرتهای پایگاه داده (Database Migrations) کاربرد دارد.
در نهایت، الوکوئنت به عنوان یکی از ویژگیهای برجسته لاراول، یک سطح انتزاعی بسیار قوی برای کار با پایگاه دادهها فراهم میکند که هم کار را سریعتر و هم کدها را تمیزتر و قابل نگهداریتر میسازد.
در بخش های بعدی با تمام موارد نام برده شده به طور مفصل آشنا خواهیم شد.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش اول - معرفی Eloquent
الوکوئنت (Eloquent) یکی از بخشهای مهم و قدرتمند فریمورک لاراول است که به عنوان ORM (Object-Relational Mapping) عمل میکند. ORM یک تکنیک برنامهنویسی است که به توسعهدهندگان اجازه میدهد تا با پایگاه داده به صورت شیءگرا کار کنند و جداول پایگاه داده را به کلاسهای PHP تبدیل کنند.
کارکرد اصلی الوکوئنت:
الکوئنت به شما امکان میدهد تا با استفاده از مدلهای شیءگرا (Objects)، دادههای پایگاه داده را دستکاری کنید. این به شما اجازه میدهد که به جای نوشتن کوئریهای SQL خام، از متدهای شیءگرای الوکوئنت استفاده کنید که کد را تمیزتر و قابلفهمتر میکند.
ویژگیها و قابلیتهای الوکوئنت:
1- تعریف مدلها: در الوکوئنت، هر جدول پایگاه داده با یک مدل مطابقت دارد. این مدلها کلاسهایی هستند که رفتارها و ویژگیهای مرتبط با جداول پایگاه داده را مشخص میکنند. همچنین یکی از سه بخش معماری MVC را تشکیل می دهند.
2- روابط: الوکوئنت به شما امکان میدهد تا روابط بین جداول را به راحتی تعریف کنید. برای مثال:
ارتباط یک به یک (One to One).
ارتباط یک به چند (One to Many).
ارتباط چند به چند (Many to Many).
ارتباطات چندشکلی که یک مدل میتواند با چندین مدل دیگر مرتبط باشد (Polymorphic).
3- اسکوپهای عمومی و محلی: میتوانید کوئریهای عمومی که به صورت مکرر استفاده میشوند را در مدل تعریف کنید (Global Scopes) یا متدهایی ایجاد کنید که اسکوپهای محلی را تعریف کنند (Local Scopes).
4- پیمایشگرها و دسترسیگرها (Mutators and Accessors): به شما اجازه میدهد تا رفتارهای خاصی را هنگام تنظیم یا گرفتن ویژگیهای یک مدل اعمال کنید.
5- رخدادها (Events): الوکوئنت دارای سیستم رخدادهایی است که شما میتوانید به آنها گوش دهید و به ازای رویدادهایی مانند creating, updating, deleting و غیره واکنش نشان دهید.
6- کوئریسازی شیءگرا (Object-Oriented Querying): الکوئنت به شما اجازه میدهد تا به جای استفاده از SQL خام، از متدهای شیءگرا برای ایجاد کوئریها استفاده کنید. این کوئریها شامل فیلتر کردن، مرتبسازی، گروهبندی و سایر عملیاتهای پیچیده میشود، بدون اینکه نیازی به نوشتن یک خط SQL باشد.
7- مهاجرتها (Migrations) و بذرها (Seeders): در کنار مدلهای الوکوئنت، لاراول ابزارهایی برای مدیریت ساختار پایگاه داده (مهاجرتها) و پر کردن جداول با دادههای نمونه (سیدر و فکتوری) فراهم میکند. این ابزارها به توسعهدهندگان کمک میکنند تا بهراحتی پایگاه دادههای خود را ایجاد و مدیریت کنند.
8- پشتیبانی از Eager Loading و Lazy Loading: الکوئنت از دو روش برای بارگذاری دادههای مرتبط با مدلها پشتیبانی میکند:
بارگذاری (Eager): این روش به شما امکان میدهد دادههای مرتبط با یک مدل را همزمان با فراخوانی مدل بارگذاری کنید تا از تعداد کوئریهای اضافی جلوگیری شود.
بارگذاری (Lazy): این روش زمانی دادههای مرتبط را بارگذاری میکند که به آنها نیاز داشته باشید. این ممکن است منجر به ارسال کوئریهای اضافی به پایگاه داده شود.
9- پشتیبانی از Soft Deletes: الکوئنت امکان (Soft Delete) را فراهم میکند که به جای حذف دائمی یک رکورد، آن را "پنهان" میکند تا بعداً بتوان آن را بازیابی کرد. این کار از طریق یک فیلد اضافی در جدول انجام میشود که تاریخ و زمان حذف را ثبت میکند.
10- و...
مزایا و کاربردهای عملی:
استفاده از الوکوئنت باعث میشود که کدها به مراتب خواناتر و قابل نگهداریتر باشند.
نیاز به نوشتن کوئریهای SQL به حداقل میرسد و توسعهدهنده میتواند روی منطق برنامه تمرکز کند.
الوکوئنت با ارائه ابزارهایی برای مدیریت روابط بین جداول، پیچیدگی مدیریت این روابط را به طور چشمگیری کاهش میدهد.
الوکوئنت برای توسعهدهندگانی که از لاراول برای ساخت برنامههای وب استفاده میکنند، ابزاری ضروری است. این ابزار در تمامی جنبههای کار با پایگاه داده از جمله تعریف مدلها، روابط، کوئریسازی و حتی مدیریت مهاجرتهای پایگاه داده (Database Migrations) کاربرد دارد.
در نهایت، الوکوئنت به عنوان یکی از ویژگیهای برجسته لاراول، یک سطح انتزاعی بسیار قوی برای کار با پایگاه دادهها فراهم میکند که هم کار را سریعتر و هم کدها را تمیزتر و قابل نگهداریتر میسازد.
در بخش های بعدی با تمام موارد نام برده شده به طور مفصل آشنا خواهیم شد.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
❤3👍3🔥3
⚜️ دوره لاراول - قسمت هفتم
📚 کنترلرها - ریسورس کنترلرها
خلاصه :
توی این ویدیو درمورد ریسورس کنترلرها حرف زدیم.
در ویدیو بعدی به مبحث ادامه کنترلرها میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/k4R85_npMC4
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 کنترلرها - ریسورس کنترلرها
خلاصه :
توی این ویدیو درمورد ریسورس کنترلرها حرف زدیم.
در ویدیو بعدی به مبحث ادامه کنترلرها میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/k4R85_npMC4
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
❤6👍3🔥2
⚜️ دوره لاراول - قسمت هشتم
📚 کنترلرها - سینگل اکشن کنترلرها و میدلورها
خلاصه :
توی این ویدیو درمورد سینگل اکشن کنترلرها و میدلورها حرف زدیم.
در ویدیو بعدی به ویوها (فرانت) میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/edC8b7F0Zj8
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 کنترلرها - سینگل اکشن کنترلرها و میدلورها
خلاصه :
توی این ویدیو درمورد سینگل اکشن کنترلرها و میدلورها حرف زدیم.
در ویدیو بعدی به ویوها (فرانت) میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/edC8b7F0Zj8
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
❤6👍5🔥2
❇️ در Laracan US 2024 چه گذشت:
- درمورد این توضیح میداد که تیم لاراول رو گشترش دادن
- درمورد اپشن هایی فرانتی که برای لاراول وجود داره به livewire و inertia js اشاره کردند.
1. ادغام laravel herd با laravel forge برای توسعه از طریق لوکال ماشین و ارتباط مستقیم روی سرور
2. اکستنشن رسمی لاراول برای vscode منتشر خواهد شده هنوز نشده و تاریخی هم نگفت. ( خیلی خیلی خفنه ترکونده )
3. درمورد temporaryUrl حرف زدن که به صورت لوکال بشه ازش استفاده کرد ( یک فایلی رو به مدت محدودی دسترسی داده بشه و بعد اون زمان 403 ارور میده )
4. درمورد کانتینر اتربیوت ها حرف زدن مثل Config , DB , CurrentUser
5. درمورد فیچر جدید eleqent که توی relations هست به اسم chaperone حرف زد
6. در مورد defer حرف زدن که خیلی راحت باهاش میتونیم یه بخشی از کار رو بندازیم تو بک گراند اجرا بشه ولی خودمون براش جاب یا پراسسی نسازیم :)))
7. متد جدید cache به اسم flexible معرفی شد که خودش داره از defer استفاده میکنه و خیلی باحاله
8. در مورد concurrency حرف زده شد که هر کاری که داده میشه توی پراسس جدایی اجرا میشه و باعث میشه سرعت برنامه بالاتر بره و شما میتونید این رو با متدی به اسم defer اجرا کنید که از همون defer که قبلا حرف زدیم استفاده میشه که سرعت برنامه بالاتر میره ( البته که بعد از ریکوئست دادن به کاربر میاد کانکارنسی رو اجرا میکنه
9. درمورد اپدیت های inertia و حرف زد
10. پلتفرم laravel cloud معرفی شد. شعارش هم هست just ship که باهاش میشه اپ های لاراول رو دیپلوی و اسکیل کرد.
خودتون ویدیو رو ببینید اینا چیزایی هست که من متوجه شدم ممکنه چیزی رو از قلم انداخته باشم یا چیزی رو اشتباه نوشته باشم❤️
⚜️ لینک ویدیو:
https://www.youtube.com/watch?v=AwWepVU5uWM
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
- درمورد این توضیح میداد که تیم لاراول رو گشترش دادن
- درمورد اپشن هایی فرانتی که برای لاراول وجود داره به livewire و inertia js اشاره کردند.
1. ادغام laravel herd با laravel forge برای توسعه از طریق لوکال ماشین و ارتباط مستقیم روی سرور
2. اکستنشن رسمی لاراول برای vscode منتشر خواهد شده هنوز نشده و تاریخی هم نگفت. ( خیلی خیلی خفنه ترکونده )
3. درمورد temporaryUrl حرف زدن که به صورت لوکال بشه ازش استفاده کرد ( یک فایلی رو به مدت محدودی دسترسی داده بشه و بعد اون زمان 403 ارور میده )
4. درمورد کانتینر اتربیوت ها حرف زدن مثل Config , DB , CurrentUser
5. درمورد فیچر جدید eleqent که توی relations هست به اسم chaperone حرف زد
6. در مورد defer حرف زدن که خیلی راحت باهاش میتونیم یه بخشی از کار رو بندازیم تو بک گراند اجرا بشه ولی خودمون براش جاب یا پراسسی نسازیم :)))
7. متد جدید cache به اسم flexible معرفی شد که خودش داره از defer استفاده میکنه و خیلی باحاله
8. در مورد concurrency حرف زده شد که هر کاری که داده میشه توی پراسس جدایی اجرا میشه و باعث میشه سرعت برنامه بالاتر بره و شما میتونید این رو با متدی به اسم defer اجرا کنید که از همون defer که قبلا حرف زدیم استفاده میشه که سرعت برنامه بالاتر میره ( البته که بعد از ریکوئست دادن به کاربر میاد کانکارنسی رو اجرا میکنه
9. درمورد اپدیت های inertia و حرف زد
10. پلتفرم laravel cloud معرفی شد. شعارش هم هست just ship که باهاش میشه اپ های لاراول رو دیپلوی و اسکیل کرد.
خودتون ویدیو رو ببینید اینا چیزایی هست که من متوجه شدم ممکنه چیزی رو از قلم انداخته باشم یا چیزی رو اشتباه نوشته باشم❤️
⚜️ لینک ویدیو:
https://www.youtube.com/watch?v=AwWepVU5uWM
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
🔥12👍5❤1
⚜️ دوره لاراول - قسمت نهم
📚 ویوها - Blade
خلاصه :
توی این ویدیو به بحث فرانت یا همین blade پرداختیم در ویدیو های بعدی به ادامه فرانت میپدازیم.
🎞 لینک ویدیو :
https://www.youtube.com/watch?v=5LYPXo44LxM
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 ویوها - Blade
خلاصه :
توی این ویدیو به بحث فرانت یا همین blade پرداختیم در ویدیو های بعدی به ادامه فرانت میپدازیم.
🎞 لینک ویدیو :
https://www.youtube.com/watch?v=5LYPXo44LxM
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
🔥7❤2👍1
⚜️ دوره لاراول - قسمت دهم
📚 ویوها - Blade Components
خلاصه :
توی این ویدیو به بحث کامپوننت ها در سیستم بلید پرداختیم
در ویدیو های بعدی به ادامه فرانت هامون میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/OT0ki4oTsSE
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 ویوها - Blade Components
خلاصه :
توی این ویدیو به بحث کامپوننت ها در سیستم بلید پرداختیم
در ویدیو های بعدی به ادامه فرانت هامون میپردازیم.
🎞 لینک ویدیو :
https://youtu.be/OT0ki4oTsSE
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
👍5❤2🔥1
Pest v3 🤩
توی لاراکان 2024 - Nuno درمورد فیچر های جدید Pest حرف میزنه که در ادامه باهم چیزایی که باحال بوده رو میبینیم ❤️
1. یک متد اضافه شده به اسم todo که میتونید برای تست ها یک todo تعریف کنید و شما میتونید شخص خاصی رو برای این todo بیاید و assign کنید یا حتی یک issue گیت هاب رو توی todo تگ کنید
2. یه متد هم به اسم issue هست که میتونید فقط یک issue گیت هاب رو تگ کنید.
3. توی اجرای تست ها یه سری فلگ اضافه شده به اسم —assign و —todos و —issue
4. یه متد دیگه به اسم done اومده که وقتی اون todo که به شخصی منسوب شده و... توسط شخص انجام میشه به جای todo از متد done استفاده میکنه و تست به خوبی pass میشه ( یه خوبی که داره مشخصه چه شخصی روی چه بخشی کار کرده و دقیقا روی چه گیت هاب issue )
5. درمورد Arch Testing حرف زده شد که روی globals و dependencies و styles میتونید تست کنید ( برای مثال ایا فانکشن گلوبال dd توی پروژه استفاده شده یا نه ، چون روی حالت پروداکشن نمیخوایم که dd استفاده شده باشه و کاربرها و... خروجی dd رو ببینند )
6. برای arch testing از فانکشن arch استفاده میشه و به شدت موارد مختلفی داره که احتمالا در اینده درموردش حرف میزنیم اینجا خیلی جای مناسبی برای تمامی موارد رو ذکر کردن نیست
7. نوشتن این همه arch test برای تیم های کوچیک و فریلنسر ها شاید خیلی سخت باشه چون بیان همه اینا رو بنویسن و... اذیت کنندس ولی pest فکر اینجا رو هم کرده یه سری preset تعریف کرده به اسم های php و security و laravel و strict و relaxed که خیلی عالین
8. یه فیچر جدید هم معرفی شده به اسم coverage که شما میتونید تست کنید که تایپ همه چیز رو مشخص کردید یا نه
9. یه فیچر جدید به اسم mutation testing اومده که به قول خودشون quality of testing رو بررسی میکنه و برای درک بهتر این موضوع میتونید ویدیو رو ببینید که خودش مثال میزنه ولی به صورت کلی میاد تک تک لاین ها رو بررسی میکنه برای مثال اگر ولیدیشن دارید هر بار یکی از rule های validation رو برمیداره و دوباره تست رو ران میکنه که ببینه fail میشه یا نه اگر fail نشه بهتون میگه که در فلان لاین فلان چیز تست نشده
اینا چیزایی هست که من فهمیدم ممکنه جایی اشتباه نوشته باشم یا هرچیز دیگری برای اینکه بهتر همه چیز رو درک کنید و با مثال ببینید بهتره ویدیو رو کامل مشاهده کنید که مثال های مختلفی که زده میشه هم ببینید ❤️
لینک ویدیو:
https://www.youtube.com/watch?v=BNhbgcNJyAk
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
توی لاراکان 2024 - Nuno درمورد فیچر های جدید Pest حرف میزنه که در ادامه باهم چیزایی که باحال بوده رو میبینیم ❤️
1. یک متد اضافه شده به اسم todo که میتونید برای تست ها یک todo تعریف کنید و شما میتونید شخص خاصی رو برای این todo بیاید و assign کنید یا حتی یک issue گیت هاب رو توی todo تگ کنید
2. یه متد هم به اسم issue هست که میتونید فقط یک issue گیت هاب رو تگ کنید.
3. توی اجرای تست ها یه سری فلگ اضافه شده به اسم —assign و —todos و —issue
4. یه متد دیگه به اسم done اومده که وقتی اون todo که به شخصی منسوب شده و... توسط شخص انجام میشه به جای todo از متد done استفاده میکنه و تست به خوبی pass میشه ( یه خوبی که داره مشخصه چه شخصی روی چه بخشی کار کرده و دقیقا روی چه گیت هاب issue )
5. درمورد Arch Testing حرف زده شد که روی globals و dependencies و styles میتونید تست کنید ( برای مثال ایا فانکشن گلوبال dd توی پروژه استفاده شده یا نه ، چون روی حالت پروداکشن نمیخوایم که dd استفاده شده باشه و کاربرها و... خروجی dd رو ببینند )
6. برای arch testing از فانکشن arch استفاده میشه و به شدت موارد مختلفی داره که احتمالا در اینده درموردش حرف میزنیم اینجا خیلی جای مناسبی برای تمامی موارد رو ذکر کردن نیست
7. نوشتن این همه arch test برای تیم های کوچیک و فریلنسر ها شاید خیلی سخت باشه چون بیان همه اینا رو بنویسن و... اذیت کنندس ولی pest فکر اینجا رو هم کرده یه سری preset تعریف کرده به اسم های php و security و laravel و strict و relaxed که خیلی عالین
8. یه فیچر جدید هم معرفی شده به اسم coverage که شما میتونید تست کنید که تایپ همه چیز رو مشخص کردید یا نه
9. یه فیچر جدید به اسم mutation testing اومده که به قول خودشون quality of testing رو بررسی میکنه و برای درک بهتر این موضوع میتونید ویدیو رو ببینید که خودش مثال میزنه ولی به صورت کلی میاد تک تک لاین ها رو بررسی میکنه برای مثال اگر ولیدیشن دارید هر بار یکی از rule های validation رو برمیداره و دوباره تست رو ران میکنه که ببینه fail میشه یا نه اگر fail نشه بهتون میگه که در فلان لاین فلان چیز تست نشده
اینا چیزایی هست که من فهمیدم ممکنه جایی اشتباه نوشته باشم یا هرچیز دیگری برای اینکه بهتر همه چیز رو درک کنید و با مثال ببینید بهتره ویدیو رو کامل مشاهده کنید که مثال های مختلفی که زده میشه هم ببینید ❤️
لینک ویدیو:
https://www.youtube.com/watch?v=BNhbgcNJyAk
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
👍8❤1🔥1
Flux -the UI Library for Livewire ✅
** توی لاراکان یه ui library هم برای لایووایر معرفی شد که خیلی چیزای باحالی داره و درکل چیز خفنیه
ولی اینجا نکته مهمه که ایا در rtl و زبان فارسی هم به همین قدرت هست یا نه :/
یک لایبرری دیگری وجود داشت به اسم maryUI این تشکیل شده بود از daisyUI و Tailwind css و Livewire ولی در زبان های rtl واقعا اذیت کننده بود.
موارد خیلی عجیب غریبی نداره که بخوام لیست کنم و بگم ولی خب یه لایبرری هست که باحاله کارمون رو راحت تر میکنه و....
برای دیدن فیچرهاش و... میتونید ویدیو لاراکان رو ببینید
لینک ویدیو:
https://www.youtube.com/watch?v=31pBMi0UdYE
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
** توی لاراکان یه ui library هم برای لایووایر معرفی شد که خیلی چیزای باحالی داره و درکل چیز خفنیه
ولی اینجا نکته مهمه که ایا در rtl و زبان فارسی هم به همین قدرت هست یا نه :/
یک لایبرری دیگری وجود داشت به اسم maryUI این تشکیل شده بود از daisyUI و Tailwind css و Livewire ولی در زبان های rtl واقعا اذیت کننده بود.
موارد خیلی عجیب غریبی نداره که بخوام لیست کنم و بگم ولی خب یه لایبرری هست که باحاله کارمون رو راحت تر میکنه و....
برای دیدن فیچرهاش و... میتونید ویدیو لاراکان رو ببینید
لینک ویدیو:
https://www.youtube.com/watch?v=31pBMi0UdYE
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
👍5❤1🔥1
⚜️ دوره لاراول - قسمت یازدهم
📚 ویوها - Layouts & Forms
خلاصه :
توی این ویدیو به بحث Layouts و فرم ها در سیستم بلید پرداختیم
در ویدیو های بعدی به الکونت و کار با دیتابیس میپردازیم.
🎞 لینک ویدیو:
https://youtu.be/AMZK8y3_pqk
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 ویوها - Layouts & Forms
خلاصه :
توی این ویدیو به بحث Layouts و فرم ها در سیستم بلید پرداختیم
در ویدیو های بعدی به الکونت و کار با دیتابیس میپردازیم.
🎞 لینک ویدیو:
https://youtu.be/AMZK8y3_pqk
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
❤7👍2🔥1
فصل چهار - مدلها و Eloquent ORM
بخش دوم - مدل ها - قسمت اول
برای ایجاد یک مدل، کافی است دستور زیر اجرا کنید:
این دستور یک فایل جدید به نام User.php در پوشه app/Models ایجاد میکند که به شکل زیر است:
هر مدل در لاراول به صورت پیشفرض به یک جدول پایگاه داده مرتبط است. لاراول با استفاده از قواعد نامگذاری، نام جدول را از نام مدل استخراج میکند. به طور مثال، مدل User به جدول users متصل میشود.
نام مدل باید به صورت مفرد (User) و نام جدول به صورت جمع (users) باشد.
اگر نام جدول شما متفاوت باشد، میتوانید آن را به صورت دستی مشخص کنید:
لاراول یک ویژگی امنیتی به نام Mass Assignment Protection دارد که به شما اجازه میدهد فیلدهایی که میتوانند به صورت گروهی پر شوند را مشخص کنید. این کار با استفاده از ویژگی $fillable انجام میشود:
با استفاده از این ویژگی، فقط فیلدهای name، email و password میتوانند به صورت گروهی پر شوند. این کار مانع از حملات احتمالی امنیتی میشود.
از این پس می توانید با استفاده از کلاس User با جدول users ارتباط برقرار کنید.
در این قسمت با متد های اصلی برای عملیات CRUD آشنا می شویم.
1- متد all
متد all تمام رکوردهای یک جدول را برمیگرداند. این متد بدون هیچ شرطی، تمامی رکوردها را برمیگرداند.
این کد تمامی رکوردهای جدول users را برمیگرداند. به خاطر داشته باشید که اگر تعداد رکوردها زیاد باشد، استفاده از این متد میتواند به عملکرد پایگاه داده آسیب بزند.
2- متد find
متد find برای یافتن یک رکورد بر اساس مقدار کلید اصلی (Primary Key) آن استفاده میشود. این متد یک رکورد را به عنوان شیء مدل بازمیگرداند یا اگر رکوردی پیدا نشود، مقدار null برمیگردد.
این کد کاربری با id برابر با ۱ را از جدول users پیدا میکند.
3- متد where
متد where برای اضافه کردن شرط به پرس و جو استفاده میشود. این متد یک یا چند شرط را برای محدود کردن نتایج اعمال میکند.
این کد تمام کاربرانی که سن آنها بالاتر از ۱۸ سال است را برمیگرداند.
میتوان از چندین شرط where پشت سر هم استفاده کرد:
این کد کاربرانی را برمیگرداند که هم فعال هستند و هم سن آنها بالاتر از ۱۸ سال است.
نکته: به طور پیشفرض اگر دو پارامتر به متد where داده شود از اپراتور = استفاده می کند، مگر ذکر شود.
4- متد orWhere
متد orWhere برای اضافه کردن شرطهای OR به پرس و جو استفاده میشود. این متد در جایی به کار میرود که میخواهیم نتایج با یکی از شرطها تطابق داشته باشند.
این کد کاربرانی را برمیگرداند که یا فعال هستند یا سن آنها بالاتر از ۱۸ سال است.
5- متد get
متد get برای بازیابی مجموعهای از رکوردها با شرایط خاص استفاده میشود. این متد بعد از استفاده از یک یا چند متد شرطی (مانند where و غیره) به کار میرود و نتایج را به صورت یک Collection برمیگرداند.
6- متد delete
متد delete برای حذف یک رکورد یا چندین رکورد از پایگاه داده استفاده میشود. برای حذف یک رکورد، ابتدا باید آن را پیدا کرده و سپس متد delete را روی آن اجرا کنیم.
این کد کاربری با id برابر با ۱ را از جدول users حذف میکند.
7- متد update
متد update برای بهروزرسانی یک یا چند فیلد از یک رکورد استفاده میشود.
این کد نام کاربری با id برابر با ۱ را به 'John Smith' تغییر میدهد.
متد create:
متد create برای ایجاد یک رکورد جدید در پایگاه داده استفاده میشود. این متد به یک آرایه از دادهها نیاز دارد که باید با ویژگیهای $fillable مدل تطابق داشته باشند.
این کد یک رکورد جدید با موارد داده شده ایجاد می کند.
در قسمت های بعدی با سایر متد ها آشنا می شویم.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - مدل ها - قسمت اول
برای ایجاد یک مدل، کافی است دستور زیر اجرا کنید:
php artisan make:model User
این دستور یک فایل جدید به نام User.php در پوشه app/Models ایجاد میکند که به شکل زیر است:
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
//
}
هر مدل در لاراول به صورت پیشفرض به یک جدول پایگاه داده مرتبط است. لاراول با استفاده از قواعد نامگذاری، نام جدول را از نام مدل استخراج میکند. به طور مثال، مدل User به جدول users متصل میشود.
نام مدل باید به صورت مفرد (User) و نام جدول به صورت جمع (users) باشد.
اگر نام جدول شما متفاوت باشد، میتوانید آن را به صورت دستی مشخص کنید:
class User extends Model
{
protected $table = 'table_name';
}
لاراول یک ویژگی امنیتی به نام Mass Assignment Protection دارد که به شما اجازه میدهد فیلدهایی که میتوانند به صورت گروهی پر شوند را مشخص کنید. این کار با استفاده از ویژگی $fillable انجام میشود:
class User extends Model
{
protected $fillable = ['name', 'email', 'password'];
}
با استفاده از این ویژگی، فقط فیلدهای name، email و password میتوانند به صورت گروهی پر شوند. این کار مانع از حملات احتمالی امنیتی میشود.
از این پس می توانید با استفاده از کلاس User با جدول users ارتباط برقرار کنید.
در این قسمت با متد های اصلی برای عملیات CRUD آشنا می شویم.
1- متد all
متد all تمام رکوردهای یک جدول را برمیگرداند. این متد بدون هیچ شرطی، تمامی رکوردها را برمیگرداند.
$users = User::all();
این کد تمامی رکوردهای جدول users را برمیگرداند. به خاطر داشته باشید که اگر تعداد رکوردها زیاد باشد، استفاده از این متد میتواند به عملکرد پایگاه داده آسیب بزند.
2- متد find
متد find برای یافتن یک رکورد بر اساس مقدار کلید اصلی (Primary Key) آن استفاده میشود. این متد یک رکورد را به عنوان شیء مدل بازمیگرداند یا اگر رکوردی پیدا نشود، مقدار null برمیگردد.
$user = User::find(1);
این کد کاربری با id برابر با ۱ را از جدول users پیدا میکند.
3- متد where
متد where برای اضافه کردن شرط به پرس و جو استفاده میشود. این متد یک یا چند شرط را برای محدود کردن نتایج اعمال میکند.
$adultUsers = User::where('age', '>', 18)->get();
این کد تمام کاربرانی که سن آنها بالاتر از ۱۸ سال است را برمیگرداند.
میتوان از چندین شرط where پشت سر هم استفاده کرد:
$filteredUsers = User::where('status', 'active')->where('age', '>', 18)->get();
این کد کاربرانی را برمیگرداند که هم فعال هستند و هم سن آنها بالاتر از ۱۸ سال است.
نکته: به طور پیشفرض اگر دو پارامتر به متد where داده شود از اپراتور = استفاده می کند، مگر ذکر شود.
4- متد orWhere
متد orWhere برای اضافه کردن شرطهای OR به پرس و جو استفاده میشود. این متد در جایی به کار میرود که میخواهیم نتایج با یکی از شرطها تطابق داشته باشند.
$users = User::where('status', 'active')->orWhere('age', '>', 18)->get();
این کد کاربرانی را برمیگرداند که یا فعال هستند یا سن آنها بالاتر از ۱۸ سال است.
5- متد get
متد get برای بازیابی مجموعهای از رکوردها با شرایط خاص استفاده میشود. این متد بعد از استفاده از یک یا چند متد شرطی (مانند where و غیره) به کار میرود و نتایج را به صورت یک Collection برمیگرداند.
6- متد delete
متد delete برای حذف یک رکورد یا چندین رکورد از پایگاه داده استفاده میشود. برای حذف یک رکورد، ابتدا باید آن را پیدا کرده و سپس متد delete را روی آن اجرا کنیم.
$user = User::find(1)->delete();
این کد کاربری با id برابر با ۱ را از جدول users حذف میکند.
7- متد update
متد update برای بهروزرسانی یک یا چند فیلد از یک رکورد استفاده میشود.
User::find(1)->update([
"username" => "John Smith"
]);
این کد نام کاربری با id برابر با ۱ را به 'John Smith' تغییر میدهد.
متد create:
متد create برای ایجاد یک رکورد جدید در پایگاه داده استفاده میشود. این متد به یک آرایه از دادهها نیاز دارد که باید با ویژگیهای $fillable مدل تطابق داشته باشند.
$user = User::create([
'name' => 'Alice Doe',
'email' => 'alice@example.com',
'password' => bcrypt('password123')
]);
این کد یک رکورد جدید با موارد داده شده ایجاد می کند.
در قسمت های بعدی با سایر متد ها آشنا می شویم.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
❤6👍1🔥1
⚜️ دوره لاراول - قسمت دوازدهم
📚 دیتابیسها - Eloquent ORM
خلاصه :
توی این ویدیو به بحث Eloquent پرداختیم
در ویدیو های بعدی به ادامه الکونت و کار با دیتابیس میپردازیم.
🎞 لینک ویدیو:
https://youtu.be/z-v068bzg0M
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 دیتابیسها - Eloquent ORM
خلاصه :
توی این ویدیو به بحث Eloquent پرداختیم
در ویدیو های بعدی به ادامه الکونت و کار با دیتابیس میپردازیم.
🎞 لینک ویدیو:
https://youtu.be/z-v068bzg0M
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
❤8👍1🔥1
فصل چهار - مدلها و Eloquent ORM
بخش دوم - مدل ها - قسمت دوم (متدهای ایجاد، ذخیره)
1- متد create
برای ایجاد و ذخیره یک مدل جدید در دیتابیس استفاده میشود. این متد یک آرایه از ویژگیها را میگیرد و یک رکورد جدید را در دیتابیس ایجاد و ذخیره میکند.
2- متد firstOrNew
سعی میکند یک رکورد مطابق با شرایط مشخص شده را در دیتابیس پیدا کند. اگر پیدا شود، همان مدل را برمیگرداند؛ در غیر این صورت، یک مدل جدید ایجاد میکند ولی آن را ذخیره نمیکند.
اگر چنین کاربری وجود داشته باشد، آن را برمیگرداند. اگر نه، یک نمونهی جدید ایجاد میکند و شما میتوانید قبل از ذخیره، اطلاعات بیشتری را به آن اضافه کنید.
3- متد firstOrCreate
مشابه firstOrNew است، اما به محض اینکه مدل جدید را ایجاد کرد، بلافاصله آن را در دیتابیس ذخیره میکند.
4- متد updateOrCreate
یک رکورد را بر اساس شرایط مشخص شده بهروز رسانی میکند و اگر وجود نداشت، یک رکورد جدید ایجاد و ذخیره میکند.
5- متد save
برای ذخیره کردن یک مدل جدید یا بهروزرسانی یک مدل موجود در دیتابیس استفاده میشود.
این کد یک نمونهی جدید از مدل User ایجاد میکند، سپس مقادیر فیلدهای name را تنظیم میکند و در نهایت آن را در دیتابیس ذخیره میکند.
6- متد saveMany
برای ذخیره کردن چندین مدل مرتبط در یک زمان استفاده میشود.
برای یک پست چندین کامنت ایجاد و ذخیره می کند (توضیح کامل تر پس از آموزش روابط دیتابیس)
7- متد saveQuietly
مشابه متد save است، با این تفاوت که رویدادهای مدل (events) را تحریک نمیکند.
8- متد createMany
برای ایجاد و ذخیره چندین مدل به طور همزمان استفاده میشود.
برای یک پست چندین کامنت ایجاد می کند (توضیح کامل تر پس از آموزش روابط دیتابیس)
9- متد createManyQuietly
مشابه createMany است، اما رویدادهای مدل (events) را تحریک نمیکند.
10- متد createQuietly
مشابه create است، اما رویدادهای مدل را تحریک نمیکند.
11- متد insert
برای وارد کردن چندین رکورد به طور همزمان در جدول دیتابیس استفاده میشود. این متد یک نمونه از مدل را برنمیگرداند.
12- متد insertOrIgnore
مانند insert است، اما اگر رکوردها در زمان درج، خطایی ایجاد کنند (مانند تکراری بودن دادهها)، این خطاها را نادیده میگیرد.
13- متد insertUsing
به شما اجازه میدهد دادهها را از یک کوئری دیگر درج کنید.
این کد کاربران غیر فعال را از جدول users انتخاب کرده و در جدول archived_users درج میکند.(توضیح سایر متد ها در قسمت های بعد).
14- متد insertGetId
یک رکورد جدید درج میکند و شناسه (ID) آن رکورد را برمیگرداند.
15- متد upsert
چندین رکورد را درج یا بهروزرسانی میکند. این متد برای شرایطی مناسب است که شما میخواهید رکوردهایی که وجود دارند را بهروزرسانی کنید و رکوردهایی که وجود ندارند را ایجاد کنید.
اگر کاربری با همان ایمیل وجود داشته باشد، فقط نامش بهروزرسانی میشود؛ وگرنه رکورد جدیدی ایجاد میشود.
16- متد updateOrInsert
این متد شبیه updateOrCreate است، با این تفاوت که مستقیماً با دیتابیس کار میکند و مدل را باز نمیگرداند.
17- متد fill
برای پر کردن مدل با دادههای مشخص استفاده میشود. این متد مدل را ذخیره نمیکند؛ تنها مقادیر فیلدها را تنظیم میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - مدل ها - قسمت دوم (متدهای ایجاد، ذخیره)
1- متد create
برای ایجاد و ذخیره یک مدل جدید در دیتابیس استفاده میشود. این متد یک آرایه از ویژگیها را میگیرد و یک رکورد جدید را در دیتابیس ایجاد و ذخیره میکند.
$user = User::create([
'name' => 'John',
]);
2- متد firstOrNew
سعی میکند یک رکورد مطابق با شرایط مشخص شده را در دیتابیس پیدا کند. اگر پیدا شود، همان مدل را برمیگرداند؛ در غیر این صورت، یک مدل جدید ایجاد میکند ولی آن را ذخیره نمیکند.
$user = User::firstOrNew(['email' => 'example@gmail.com']);
$user->name = 'John';
$user->save();
اگر چنین کاربری وجود داشته باشد، آن را برمیگرداند. اگر نه، یک نمونهی جدید ایجاد میکند و شما میتوانید قبل از ذخیره، اطلاعات بیشتری را به آن اضافه کنید.
3- متد firstOrCreate
مشابه firstOrNew است، اما به محض اینکه مدل جدید را ایجاد کرد، بلافاصله آن را در دیتابیس ذخیره میکند.
$user = User::firstOrCreate(
['email' => 'example@gmail.com'],
['name' => 'John']
);
4- متد updateOrCreate
یک رکورد را بر اساس شرایط مشخص شده بهروز رسانی میکند و اگر وجود نداشت، یک رکورد جدید ایجاد و ذخیره میکند.
$user = User::updateOrCreate(
['email' => 'example@gmail.com'],
['name' => 'John']
);
5- متد save
برای ذخیره کردن یک مدل جدید یا بهروزرسانی یک مدل موجود در دیتابیس استفاده میشود.
$user = new User;
$user->name = 'John';
$user->save();
این کد یک نمونهی جدید از مدل User ایجاد میکند، سپس مقادیر فیلدهای name را تنظیم میکند و در نهایت آن را در دیتابیس ذخیره میکند.
6- متد saveMany
برای ذخیره کردن چندین مدل مرتبط در یک زمان استفاده میشود.
$post = Post::find(1);
$comments = [
new Comment(['message' => 'First']),
new Comment(['message' => 'Second']),
];
$post->comments()->saveMany($comments);
برای یک پست چندین کامنت ایجاد و ذخیره می کند (توضیح کامل تر پس از آموزش روابط دیتابیس)
7- متد saveQuietly
مشابه متد save است، با این تفاوت که رویدادهای مدل (events) را تحریک نمیکند.
8- متد createMany
برای ایجاد و ذخیره چندین مدل به طور همزمان استفاده میشود.
$post = Post::find(1);
$post->comments()->createMany([
['message' => 'First'],
['message' => 'Second']
]);
برای یک پست چندین کامنت ایجاد می کند (توضیح کامل تر پس از آموزش روابط دیتابیس)
9- متد createManyQuietly
مشابه createMany است، اما رویدادهای مدل (events) را تحریک نمیکند.
10- متد createQuietly
مشابه create است، اما رویدادهای مدل را تحریک نمیکند.
11- متد insert
برای وارد کردن چندین رکورد به طور همزمان در جدول دیتابیس استفاده میشود. این متد یک نمونه از مدل را برنمیگرداند.
User::insert([
['name' => 'John'],
['name' => 'Jane']
]);
12- متد insertOrIgnore
مانند insert است، اما اگر رکوردها در زمان درج، خطایی ایجاد کنند (مانند تکراری بودن دادهها)، این خطاها را نادیده میگیرد.
13- متد insertUsing
به شما اجازه میدهد دادهها را از یک کوئری دیگر درج کنید.
ArchivedUser::insertUsing(['name', 'email'], function ($query) {
$query->select('name', 'email')->from('users')->where('active', 0);
});
این کد کاربران غیر فعال را از جدول users انتخاب کرده و در جدول archived_users درج میکند.(توضیح سایر متد ها در قسمت های بعد).
14- متد insertGetId
یک رکورد جدید درج میکند و شناسه (ID) آن رکورد را برمیگرداند.
User::insertGetId(
['name' => 'John']
);
15- متد upsert
چندین رکورد را درج یا بهروزرسانی میکند. این متد برای شرایطی مناسب است که شما میخواهید رکوردهایی که وجود دارند را بهروزرسانی کنید و رکوردهایی که وجود ندارند را ایجاد کنید.
User::upsert([
['email' => 'john@gmail.com', 'name' => 'John'],
['email' => 'jane@gmail.com', 'name' => 'Jane']
], ['email'], ['name']);
اگر کاربری با همان ایمیل وجود داشته باشد، فقط نامش بهروزرسانی میشود؛ وگرنه رکورد جدیدی ایجاد میشود.
16- متد updateOrInsert
این متد شبیه updateOrCreate است، با این تفاوت که مستقیماً با دیتابیس کار میکند و مدل را باز نمیگرداند.
17- متد fill
برای پر کردن مدل با دادههای مشخص استفاده میشود. این متد مدل را ذخیره نمیکند؛ تنها مقادیر فیلدها را تنظیم میکند.
$user = new User;
$user->fill(['name' => 'John']);
$user->save();
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
❤5👍3🔥2
فصل چهار - مدلها و Eloquent ORM
بخش دوم - مدل ها - قسمت سوم (متدهای ویرایش، حذف)
1- متد update
برای بهروزرسانی رکوردهای موجود در دیتابیس استفاده میشود.
این کد فیلد name تمام کاربران با ایمیل مشخص شده را به 'John' تغییر میدهد.
2- متد increment
برای افزایش مقدار یک فیلد عددی استفاده میشود.
این کد مقدار فیلد age کاربر با id 1 را به اندازه 2 افزایش میدهد.
3- متد decrement
برای کاهش مقدار یک فیلد عددی استفاده میشود.
این کد مقدار فیلد age کاربر با id 1 را به اندازه 2 کاهش میدهد.
4- متد incrementEach
برای افزایش مقدار یک فیلد عددی در چندین رکورد به طور همزمان استفاده میشود.
این کد مقدار فیلد credits را برای کاربران با شناسههای 1، 2 و 3 به اندازه 5 افزایش میدهد.
5- متد decrementEach
برای کاهش مقدار یک فیلد عددی در چندین رکورد به طور همزمان استفاده میشود.
این کد مقدار فیلد credits را برای کاربران با شناسههای 1، 2 و 3 به اندازه 5 کاهش میدهد.
6- متد delete
برای حذف رکوردهای موجود در دیتابیس استفاده میشود.
این کد کاربر با id 1 را از دیتابیس حذف میکند.
7- متد truncate
برای حذف تمام رکوردها از یک جدول و بازنشانی auto-increment استفاده میشود.
این کد تمام کاربران را از جدول users حذف میکند و شناسه خودکار را به مقدار اولیه بازنشانی میکند.
8- متد deleteQuietly
مشابه delete است، اما رویدادهای مدل را تحریک نمیکند.
9- متد forceDelete
برای حذف دائم رکوردها از دیتابیس استفاده میشود، حتی اگر از ویژگی Soft Delete استفاده شود.
این کد کاربر با id 1 را به طور دائم از دیتابیس حذف میکند.
10- متد forceDeleteQuietly
مشابه forceDelete است، اما رویدادهای مدل را تحریک نمیکند.
11- متد destroy
برای حذف یک یا چند رکورد با شناسههای مشخص استفاده میشود.
این کد کاربران با شناسههای 1، 2 و 3 را از دیتابیس حذف میکند.
12- متد forceDestroy
برای حذف دائم یک یا چند رکورد حتی با استفاده از ویژگی Soft Delete استفاده میشود.
این کد کاربران با شناسههای 1، 2 و 3 را به طور دائم از دیتابیس حذف میکند، حتی اگر در حالت Soft Delete باشند.
13- متد restore
برای بازیابی رکوردهایی که Soft Delete شدهاند، استفاده میشود.
این کد کاربر با id 1 را که Soft Delete شده بود، بازیابی میکند.
14- متد restoreQuietly
مشابه restore است، اما رویدادهای مدل را تحریک نمیکند.
15- متد replicate
برای ایجاد یک کپی از یک مدل موجود استفاده میشود.
این کد یک کپی از کاربر با id 1 ایجاد کرده و آن را به عنوان یک رکورد جدید ذخیره میکند.
16- متد withTrashed
به شما اجازه میدهد رکوردهایی که Soft Delete شده اند را نیز در نتایج جستجو بازگردانید.
این کد تمام کاربران با نام 'John' را برمیگرداند، حتی آنهایی که Soft Delete شدهاند.
17- متد onlyTrashed
به شما اجازه میدهد تنها رکوردهایی که Soft Delete شده اند را در نتایج جستجو بازگردانید.
این کد تمام کاربران با نام 'John' که Soft Delete شدهاند را برمیگرداند.
18- متد trashed
بررسی میکند که آیا یک رکورد خاص Soft Delete شده است یا خیر.
این کد بررسی میکند که آیا کاربر با id برابر 1 Soft Delete شده است یا خیر و اگر بله، کدی را اجرا میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - مدل ها - قسمت سوم (متدهای ویرایش، حذف)
1- متد update
برای بهروزرسانی رکوردهای موجود در دیتابیس استفاده میشود.
User::where('email', 'example@gmail.com')->update(['name' => 'John']);
این کد فیلد name تمام کاربران با ایمیل مشخص شده را به 'John' تغییر میدهد.
2- متد increment
برای افزایش مقدار یک فیلد عددی استفاده میشود.
User::where('id', 1)->increment('age', 2);
این کد مقدار فیلد age کاربر با id 1 را به اندازه 2 افزایش میدهد.
3- متد decrement
برای کاهش مقدار یک فیلد عددی استفاده میشود.
User::where('id', 1)->decrement('age', 2);
این کد مقدار فیلد age کاربر با id 1 را به اندازه 2 کاهش میدهد.
4- متد incrementEach
برای افزایش مقدار یک فیلد عددی در چندین رکورد به طور همزمان استفاده میشود.
User::whereIn('id', [1, 2, 3])->incrementEach('credits', 5);
این کد مقدار فیلد credits را برای کاربران با شناسههای 1، 2 و 3 به اندازه 5 افزایش میدهد.
5- متد decrementEach
برای کاهش مقدار یک فیلد عددی در چندین رکورد به طور همزمان استفاده میشود.
User::whereIn('id', [1, 2, 3])->decrementEach('credits', 5);
این کد مقدار فیلد credits را برای کاربران با شناسههای 1، 2 و 3 به اندازه 5 کاهش میدهد.
6- متد delete
برای حذف رکوردهای موجود در دیتابیس استفاده میشود.
User::where('id', 1)->delete();
این کد کاربر با id 1 را از دیتابیس حذف میکند.
7- متد truncate
برای حذف تمام رکوردها از یک جدول و بازنشانی auto-increment استفاده میشود.
User::truncate();
این کد تمام کاربران را از جدول users حذف میکند و شناسه خودکار را به مقدار اولیه بازنشانی میکند.
8- متد deleteQuietly
مشابه delete است، اما رویدادهای مدل را تحریک نمیکند.
9- متد forceDelete
برای حذف دائم رکوردها از دیتابیس استفاده میشود، حتی اگر از ویژگی Soft Delete استفاده شود.
User::find(1)->forceDelete();
این کد کاربر با id 1 را به طور دائم از دیتابیس حذف میکند.
10- متد forceDeleteQuietly
مشابه forceDelete است، اما رویدادهای مدل را تحریک نمیکند.
11- متد destroy
برای حذف یک یا چند رکورد با شناسههای مشخص استفاده میشود.
User::destroy([1, 2, 3]);
این کد کاربران با شناسههای 1، 2 و 3 را از دیتابیس حذف میکند.
12- متد forceDestroy
برای حذف دائم یک یا چند رکورد حتی با استفاده از ویژگی Soft Delete استفاده میشود.
User::forceDestroy([1, 2, 3]);
این کد کاربران با شناسههای 1، 2 و 3 را به طور دائم از دیتابیس حذف میکند، حتی اگر در حالت Soft Delete باشند.
13- متد restore
برای بازیابی رکوردهایی که Soft Delete شدهاند، استفاده میشود.
User::where('id', 1)->restore();
این کد کاربر با id 1 را که Soft Delete شده بود، بازیابی میکند.
14- متد restoreQuietly
مشابه restore است، اما رویدادهای مدل را تحریک نمیکند.
15- متد replicate
برای ایجاد یک کپی از یک مدل موجود استفاده میشود.
$user = User::find(1);
$newUser = $user->replicate();
$newUser->save();
این کد یک کپی از کاربر با id 1 ایجاد کرده و آن را به عنوان یک رکورد جدید ذخیره میکند.
16- متد withTrashed
به شما اجازه میدهد رکوردهایی که Soft Delete شده اند را نیز در نتایج جستجو بازگردانید.
$users = User::withTrashed()->where('name', 'John')->get();
این کد تمام کاربران با نام 'John' را برمیگرداند، حتی آنهایی که Soft Delete شدهاند.
17- متد onlyTrashed
به شما اجازه میدهد تنها رکوردهایی که Soft Delete شده اند را در نتایج جستجو بازگردانید.
$users = User::onlyTrashed()->where('name', 'John')->get();
این کد تمام کاربران با نام 'John' که Soft Delete شدهاند را برمیگرداند.
18- متد trashed
بررسی میکند که آیا یک رکورد خاص Soft Delete شده است یا خیر.
$user = User::find(1);
if ($user->trashed()) {
//
}
این کد بررسی میکند که آیا کاربر با id برابر 1 Soft Delete شده است یا خیر و اگر بله، کدی را اجرا میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
👍8❤2🔥1
فصل چهار - مدلها و Eloquent ORM
بخش دوم - مدل ها - قسمت چهارم (متدهای بازیابی)
1- متد get
برای بازیابی مجموعهای از رکوردها از دیتابیس استفاده میشود.
2- متد first
اولین رکورد مطابق با شرایط مشخص شده را بازیابی میکند.
3- متد firstOrFail
اولین رکورد مطابق با شرایط را بازیابی میکند؛ اگر رکوردی یافت نشود، یک استثنا برگشت داده میشود.
4- متد value
برای بازیابی مقدار یک فیلد خاص از اولین رکورد مطابق با شرایط استفاده میشود.
این کد مقدار فیلد email اولین کاربری که نام آن 'John' باشد را برمیگرداند.
5- متد find
برای بازیابی رکوردی با شناسه (ID) مشخص استفاده میشود.
6- متد pluck
برای بازیابی مقادیر یک ستون خاص از تمام رکوردهای مطابق استفاده میشود.
این کد تمامی ایمیلهای کاربران با وضعیت 'active' را به صورت آرایهای از مقادیر برمیگرداند.
7- متد select
برای انتخاب ستونهای خاص از جدول استفاده میشود.
این کد فقط نام و ایمیل تمام کاربران را از دیتابیس بازیابی میکند.
8- متد distinct
برای انتخاب مقادیر منحصر به فرد (یونیک) از یک ستون خاص استفاده میشود.
این کد تمامی نامهای منحصر به فرد کاربران را از دیتابیس بازیابی میکند.
9- متد addSelect
برای اضافه کردن ستونهای بیشتر به یک کوئری select استفاده میشود.
این کد ابتدا ستون name را انتخاب میکند و سپس ستون email را به کوئری اضافه میکند.
10- متد selectRaw
برای نوشتن کوئریهای خام SQL استفاده میشود.
این کد نام کاربران را به همراه تعداد رکوردهای مربوط به هر نام، با استفاده از کوئری خام SQL، بازیابی میکند.
11- متد firstWhere
اولین رکورد مطابق با شرایط مشخص شده را بازیابی میکند.
این کد اولین کاربری که نام آن 'John' باشد را بازیابی میکند.
12- متد findOr
رکوردی با شناسه مشخص را بازیابی میکند یا یک عمل جایگزین را اجرا میکند اگر یافت نشد.
این کد کاربری با شناسه 1 را پیدا میکند. اگر وجود نداشته باشد، یک کاربر جدید با نام 'Default User' ایجاد میکند.
13- متد firstOr
اولین رکورد مطابق با شرایط را بازیابی میکند یا یک عمل جایگزین را اجرا میکند اگر رکورد یافت نشد.
این کد اولین کاربری که نام آن 'John' باشد را بازیابی میکند. اگر وجود نداشته باشد، یک کاربر جدید با نام 'Default User' ایجاد میکند.
14- متد findOrFail
رکوردی با شناسه مشخص را بازیابی میکند. اگر وجود نداشته باشد، یک استثنا برگشت داده میشود.
این کد کاربری با شناسه 1 را بازیابی میکند. اگر وجود نداشته باشد، یک استثنا برگشت داده میشود.
15- متد findOrNew
رکوردی با شناسه مشخص را بازیابی میکند یا یک مدل جدید ایجاد میکند اگر رکورد یافت نشد.
این کد کاربری با شناسه 1 را بازیابی میکند. اگر کاربری با این شناسه وجود نداشته باشد، یک نمونه جدید از مدل User ایجاد میکند.
16- متد firstOrCreate
تلاش میکند اولین رکورد مطابق با شرایط را پیدا کند؛ اگر یافت نشد، یک رکورد جدید ایجاد و در دیتابیس ذخیره میکند.
این کد تلاش میکند تا اولین کاربر با ایمیل 'test@gmail.com' را پیدا کند. اگر وجود نداشت، یک کاربر جدید با ادغام دو ورودی ایجاد میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - مدل ها - قسمت چهارم (متدهای بازیابی)
1- متد get
برای بازیابی مجموعهای از رکوردها از دیتابیس استفاده میشود.
$users = User::where('status', 'active')->get();
2- متد first
اولین رکورد مطابق با شرایط مشخص شده را بازیابی میکند.
$user = User::where('status', 'active')->first();
3- متد firstOrFail
اولین رکورد مطابق با شرایط را بازیابی میکند؛ اگر رکوردی یافت نشود، یک استثنا برگشت داده میشود.
$user = User::where('status', 'active')->firstOrFail();
4- متد value
برای بازیابی مقدار یک فیلد خاص از اولین رکورد مطابق با شرایط استفاده میشود.
$email = User::where('name', 'John')->value('email');
این کد مقدار فیلد email اولین کاربری که نام آن 'John' باشد را برمیگرداند.
5- متد find
برای بازیابی رکوردی با شناسه (ID) مشخص استفاده میشود.
$user = User::find(1);
6- متد pluck
برای بازیابی مقادیر یک ستون خاص از تمام رکوردهای مطابق استفاده میشود.
$emails = User::where('status', 'active')->pluck('email');
این کد تمامی ایمیلهای کاربران با وضعیت 'active' را به صورت آرایهای از مقادیر برمیگرداند.
7- متد select
برای انتخاب ستونهای خاص از جدول استفاده میشود.
$users = User::select('name', 'email')->get();
این کد فقط نام و ایمیل تمام کاربران را از دیتابیس بازیابی میکند.
8- متد distinct
برای انتخاب مقادیر منحصر به فرد (یونیک) از یک ستون خاص استفاده میشود.
$names = User::select('name')->distinct()->get();
این کد تمامی نامهای منحصر به فرد کاربران را از دیتابیس بازیابی میکند.
9- متد addSelect
برای اضافه کردن ستونهای بیشتر به یک کوئری select استفاده میشود.
$users = User::select('name')->addSelect('email')->get();
این کد ابتدا ستون name را انتخاب میکند و سپس ستون email را به کوئری اضافه میکند.
10- متد selectRaw
برای نوشتن کوئریهای خام SQL استفاده میشود.
$users = User::selectRaw('name, COUNT(*) as count')->groupBy('name')->get();
این کد نام کاربران را به همراه تعداد رکوردهای مربوط به هر نام، با استفاده از کوئری خام SQL، بازیابی میکند.
11- متد firstWhere
اولین رکورد مطابق با شرایط مشخص شده را بازیابی میکند.
$user = User::firstWhere('name', 'John');
این کد اولین کاربری که نام آن 'John' باشد را بازیابی میکند.
12- متد findOr
رکوردی با شناسه مشخص را بازیابی میکند یا یک عمل جایگزین را اجرا میکند اگر یافت نشد.
$user = User::findOr(1, function () {
return new User(['name' => 'Default User']);
});
این کد کاربری با شناسه 1 را پیدا میکند. اگر وجود نداشته باشد، یک کاربر جدید با نام 'Default User' ایجاد میکند.
13- متد firstOr
اولین رکورد مطابق با شرایط را بازیابی میکند یا یک عمل جایگزین را اجرا میکند اگر رکورد یافت نشد.
$user = User::where('name', 'John')->firstOr(function () {
return new User(['name' => 'Default User']);
});
این کد اولین کاربری که نام آن 'John' باشد را بازیابی میکند. اگر وجود نداشته باشد، یک کاربر جدید با نام 'Default User' ایجاد میکند.
14- متد findOrFail
رکوردی با شناسه مشخص را بازیابی میکند. اگر وجود نداشته باشد، یک استثنا برگشت داده میشود.
$user = User::findOrFail(1);
این کد کاربری با شناسه 1 را بازیابی میکند. اگر وجود نداشته باشد، یک استثنا برگشت داده میشود.
15- متد findOrNew
رکوردی با شناسه مشخص را بازیابی میکند یا یک مدل جدید ایجاد میکند اگر رکورد یافت نشد.
$user = User::findOrNew(1);
این کد کاربری با شناسه 1 را بازیابی میکند. اگر کاربری با این شناسه وجود نداشته باشد، یک نمونه جدید از مدل User ایجاد میکند.
16- متد firstOrCreate
تلاش میکند اولین رکورد مطابق با شرایط را پیدا کند؛ اگر یافت نشد، یک رکورد جدید ایجاد و در دیتابیس ذخیره میکند.
$user = User::firstOrCreate(
['email' => 'test@gmail.com'],
['name' => 'John']
);
این کد تلاش میکند تا اولین کاربر با ایمیل 'test@gmail.com' را پیدا کند. اگر وجود نداشت، یک کاربر جدید با ادغام دو ورودی ایجاد میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
👍3❤1
فصل چهار - مدلها و Eloquent ORM
بخش دوم - مدل ها - قسمت پنجم (متدهای شرطی - 1)
1- متد where
رای اعمال یک شرط بر روی کوئری استفاده میشود.
این کد تمام کاربران با وضعیت 'active' و سن بزرگتر از 18 را بازیابی میکند.
2- متد orWhere
برای اعمال یک شرط OR بر روی کوئری استفاده میشود.
این کد تمام کاربران با وضعیت 'active' یا کاربرانی که سن آنها بیشتر از ۱۸ است را بازیابی میکند.
3- متد whereNot
برای اعمال شرطی که مخالف یک شرط مشخص است، استفاده میشود.
ین کد تمام کاربرانی که وضعیت آنها 'inactive' نیست را بازیابی میکند.
4- متد orWhereNot
برای اعمال یک شرط OR که مخالف یک شرط مشخص است، استفاده میشود.
این کد تمام کاربرانی که سن آنها کمتر از ۳۰ است یا وضعیت آنها 'inactive' نیست را بازیابی میکند.
5- متد whereRaw
به شما اجازه میدهد که یک شرط خام SQL را به کوئری اضافه کنید.
این کد تمام کاربران با سن بیشتر از ۱۸ و وضعیت 'active' را بازیابی میکند.
6- متد orWhereRaw
برای افزودن شرط OR به یک کوئری با استفاده از SQL خام استفاده میشود.
این کد تمام کاربران با وضعیت 'active' یا سن بیشتر از ۱۸ را بازیابی میکند.
7- متد whereColumn
برای اعمال شرطی که دو ستون را با یکدیگر مقایسه میکند، استفاده میشود.
این کد تمام کاربرانی را که تاریخ ایجاد آنها جدیدتر از تاریخ بهروزرسانیشان است، بازیابی میکند.
8- متد whereNull
برای جستجوی رکوردهایی که مقدار مشخصی در آنها NULL است، استفاده میشود.
این کد تمام کاربرانی که فیلد deleted_at آنها مقدار NULL دارد (حذف نشدهاند)، بازیابی میکند.
9- متد whereNotNull
رای جستجوی رکوردهایی که مقدار مشخصی در آنها NULL نیست، استفاده میشود.
این کد تمام کاربرانی که فیلد email آنها مقدار NULL ندارد را بازیابی میکند.
10- متد whereDate
برای فیلتر کردن رکوردها بر اساس تاریخ استفاده میشود.
11- متد whereMonth
برای فیلتر کردن رکوردها بر اساس ماه استفاده میشود.
12- متد whereDay
برای فیلتر کردن رکوردها بر اساس روز استفاده میشود.
13- متد whereYear
برای فیلتر کردن رکوردها بر اساس سال استفاده میشود.
14- متد whereTime
برای فیلتر کردن رکوردها بر اساس زمان استفاده میشود.
15- متد whereAny
برای فیلتر کردن رکوردها با هر یک از شرایط مشخص استفاده میشود.
این کد تمام کاربرانی را که وضعیت آنها 'active' است یا سن آنها بیشتر از ۱۸ است، بازیابی میکند.
16- متد whereAll
برای فیلتر کردن رکوردها با تمام شرایط مشخص استفاده میشود.
این کد تمام کاربرانی را که وضعیت آنها 'active' و سن آنها بیشتر از ۱۸ است، بازیابی میکند.
17- متد whereNone
برای فیلتر کردن رکوردهایی که هیچکدام از شرایط مشخص را ندارند، استفاده میشود.
این کد تمام کاربرانی را که وضعیت آنها 'inactive' نیست و سن آنها کمتر از ۱۸ نیست، بازیابی میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - مدل ها - قسمت پنجم (متدهای شرطی - 1)
1- متد where
رای اعمال یک شرط بر روی کوئری استفاده میشود.
$users = User::where('status', 'active')->where('age', '>', '18')->get();
این کد تمام کاربران با وضعیت 'active' و سن بزرگتر از 18 را بازیابی میکند.
2- متد orWhere
برای اعمال یک شرط OR بر روی کوئری استفاده میشود.
$users = User::where('status', 'active')->orWhere('age', '>', 18)->get();
این کد تمام کاربران با وضعیت 'active' یا کاربرانی که سن آنها بیشتر از ۱۸ است را بازیابی میکند.
3- متد whereNot
برای اعمال شرطی که مخالف یک شرط مشخص است، استفاده میشود.
$users = User::whereNot('status', 'inactive')->get();
ین کد تمام کاربرانی که وضعیت آنها 'inactive' نیست را بازیابی میکند.
4- متد orWhereNot
برای اعمال یک شرط OR که مخالف یک شرط مشخص است، استفاده میشود.
$users = User::where('age', '<', 30)->orWhereNot('status', 'inactive')->get();
این کد تمام کاربرانی که سن آنها کمتر از ۳۰ است یا وضعیت آنها 'inactive' نیست را بازیابی میکند.
5- متد whereRaw
به شما اجازه میدهد که یک شرط خام SQL را به کوئری اضافه کنید.
$users = User::whereRaw('age > ? AND status = ?', [18, 'active'])->get();
این کد تمام کاربران با سن بیشتر از ۱۸ و وضعیت 'active' را بازیابی میکند.
6- متد orWhereRaw
برای افزودن شرط OR به یک کوئری با استفاده از SQL خام استفاده میشود.
$users = User::where('status', 'active')->orWhereRaw('age > ?', [18])->get();
این کد تمام کاربران با وضعیت 'active' یا سن بیشتر از ۱۸ را بازیابی میکند.
7- متد whereColumn
برای اعمال شرطی که دو ستون را با یکدیگر مقایسه میکند، استفاده میشود.
$users = User::whereColumn('created_at', '>', 'updated_at')->get();
این کد تمام کاربرانی را که تاریخ ایجاد آنها جدیدتر از تاریخ بهروزرسانیشان است، بازیابی میکند.
8- متد whereNull
برای جستجوی رکوردهایی که مقدار مشخصی در آنها NULL است، استفاده میشود.
$users = User::whereNull('deleted_at')->get();
این کد تمام کاربرانی که فیلد deleted_at آنها مقدار NULL دارد (حذف نشدهاند)، بازیابی میکند.
9- متد whereNotNull
رای جستجوی رکوردهایی که مقدار مشخصی در آنها NULL نیست، استفاده میشود.
$users = User::whereNotNull('email')->get();
این کد تمام کاربرانی که فیلد email آنها مقدار NULL ندارد را بازیابی میکند.
10- متد whereDate
برای فیلتر کردن رکوردها بر اساس تاریخ استفاده میشود.
$users = User::whereDate('created_at', '2024-09-12')->get();
11- متد whereMonth
برای فیلتر کردن رکوردها بر اساس ماه استفاده میشود.
$users = User::whereMonth('created_at', '09')->get();
12- متد whereDay
برای فیلتر کردن رکوردها بر اساس روز استفاده میشود.
$users = User::whereDay('created_at', '12')->get();
13- متد whereYear
برای فیلتر کردن رکوردها بر اساس سال استفاده میشود.
$users = User::whereYear('created_at', '2024')->get();
14- متد whereTime
برای فیلتر کردن رکوردها بر اساس زمان استفاده میشود.
$users = User::whereTime('created_at', '14:30:00')->get();
15- متد whereAny
برای فیلتر کردن رکوردها با هر یک از شرایط مشخص استفاده میشود.
$users = User::whereAny([
['status', 'active'],
['age', '>', 18]
])->get();
این کد تمام کاربرانی را که وضعیت آنها 'active' است یا سن آنها بیشتر از ۱۸ است، بازیابی میکند.
16- متد whereAll
برای فیلتر کردن رکوردها با تمام شرایط مشخص استفاده میشود.
$users = User::whereAll([
['status', 'active'],
['age', '>', 18]
])->get();
این کد تمام کاربرانی را که وضعیت آنها 'active' و سن آنها بیشتر از ۱۸ است، بازیابی میکند.
17- متد whereNone
برای فیلتر کردن رکوردهایی که هیچکدام از شرایط مشخص را ندارند، استفاده میشود.
$users = User::whereNone([
['status', 'inactive'],
['age', '<', 18]
])->get();
این کد تمام کاربرانی را که وضعیت آنها 'inactive' نیست و سن آنها کمتر از ۱۸ نیست، بازیابی میکند.
🔖 #Laravel, #PHP, #لاراول, #فصل_۴
👤 AmirHossein
💎 Channel: @DevelopixLaravel
🔥5❤3👍3