برنامه نویسی

Livewire چیست و چه کاربردی دارد؟ + مثال آموزشی

با توجه به پیشرفت چشمگیر استفاده از وب اپلیکیشن‌های مدرن، استفاده از ابزارهایی برای تسهیل فرآیند ساخت آن‌ها، امری ضروری است. ابزارهایی مانند Vue یا React، در این زمینه بسیار قدرتمند هستند، اما استفاده از آن‌ها برای یک توسعه دهنده‌ی فول استک، پیچیدگی‌هایی دارد که غیرقابل اجتناب است. در این مقاله قصد داریم به آموزش Livewire در لاراول بپردازیم. Livewire چیست؟ Livewire یک فریم‌ورک فول استک برای لاراول است که فرآیند ایجاد رابط‌های کاربری داینامیک را در وب اپلیکیشن‌های مدرن به سادگی امکان‌پذیر می‌کند.

اگر دانش کافی در زمینه فریم‌ورک لاراول را دارید و نیاز دارید یک وب اپلیکیشن پویا را بدون استفاده از فریم‌ورک‌های پیچیده جاوااسکریپت مانند Vue.js ایجاد کنید، Livewire بهترین گزینه برای شما است. این فریم‌ورک به خصوص برای ساخت برنامه‌های تک صفحه‌ای یا SPA بسیار کارآمد است. با استفاده از Livewire، نیازی به نوشتن کدهای jQuery برای درخواست‌های Ajax در وب اپلیکیشن خود نخواهید داشت و Livewire به شما کمک می‌کند تا بدون نیاز به تازه‌سازی صفحه، عملیات‌هایی مانند اعتبارسنجی فرم، ثبت فرم، ذخیره فایل و غیره را انجام دهید.

آیا Livewire قابل استفاده در تمام نسخه‌های لاراول است؟

Livewire قابل استفاده در تمام نسخه‌های Laravel است. ابتدا Livewire در نسخه ۷.x از Laravel معرفی شد و از آن زمان به بعد به طور پیوسته بهبود یافت و به نسخه‌های جدیدتر نیز اضافه شد. بنابراین، می‌توانید Livewire را در نسخه‌های جدیدتر و قدیمی‌تر از Laravel بکار ببرید. همچنین، توصیه می‌شود برای استفاده از Livewire، از آخرین نسخه موجود Laravel استفاده کنید تا بهره‌وری و قابلیت‌های کامل این فریم‌ورک را بیشتر تجربه کنید.

نحوه‌ی کار Livewire چگونه است؟

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

نصب و راه‌اندازی: ابتدا باید Livewire را در پروژه Laravel خود نصب کنید. این کار با استفاده از ابزار Composer انجام می‌شود. با اجرای دستور زیر، بسته Livewire به پروژه شما اضافه می‌شود:

composer require livewire/livewire

ایجاد کامپوننت: پس از نصب Livewire، باید کامپوننت‌های Livewire را ایجاد کنید. کامپوننت‌ها مسئول ایجاد رابط‌های کاربری پویا هستند. برای ساخت کامپوننت جدید، می‌توانید از دستور زیر استفاده کنید:

php artisan make:livewire MyComponent

این دستور یک فایل کامپوننت با نام MyComponent.php در مسیر `app/Http/Livewire` ایجاد می‌کند.

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

پیوند کامپوننت با صفحات: برای استفاده از کامپوننت Livewire در صفحات، باید آن‌ها را به صفحات مربوطه پیوند دهید. این کار با استفاده از دستور `@livewire` در صفحات Blade انجام می‌شود. به عنوان مثال:

@livewire('my-component')

این دستور کامپوننت MyComponent را به صفحه فعلی متصل می‌کند.

  1. پردازش رویدادها و درخواست‌ها: Livewire به طور خودکار رویدادها و درخواست‌های کاربر را پردازش می‌کند. با استفاده از روش‌های موجود در کامپوننت، می‌توانید به رویدادها و درخواست‌ها پاسخ دهید و تغییرات مورد نیاز را در صفحه اعمال کنید. این شامل تحلیل والیدیشن داده‌ها، به‌روزرسانی متغیرها و بروزرسانی قسمت‌های مختلف صفحه است.
  2. بروزرسانی صفحه بدون Refresh: یکی از ویژگی‌های قدرتمند Livewire، قابلیت بروزرسانی صفحه بدون نیازبه Refresh کردن صفحه است. با استفاده از Livewire، تغییرات و عملیات مربوط به رابط کاربری را می‌توانید به صورت پویا و بدون تازه‌سازی صفحه اعمال کنید.

این توضیحات مربوط به روند کلی کار با Livewire است. با استفاده از این فریم‌ورک، می‌توانید رابط‌های کاربری پویا و بدون نیاز به فریم‌ورک‌های پیچیده‌ی جاوااسکریپت مانند Vue.js ایجاد کنید. Livewire با استفاده از تکنیک‌های Ajax و دستورات دیگر، امکان بروزرسانی پویا و بدون نیاز به Refresh کردن صفحه را فراهم می‌کند.

نیازمندی‌های اولیه در livewire

برای استفاده از Livewire در پروژه‌های Laravel، این موارد را لازم خواهید داشت:

  1. نسخه Laravel: Livewire با نسخه‌های جدیدتر Laravel سازگاری کامل‌تری دارد. بنابراین، برای استفاده بهینه از Livewire، توصیه می‌شود از آخرین نسخه معتبر Laravel استفاده کنید.
  2. نصب Livewire: باید بسته Livewire را در پروژه Laravel خود نصب کنید. می‌توانید از Composer برای نصب Livewire استفاده کنید با اجرای دستور زیر:
    ` composer require livewire/livewire
  3. نسخه PHP: Livewire نیاز به نسخه PHP 7.3 یا بالاتر دارد. از این رو، باید مطمئن شوید که نسخه PHP پروژه شما از این حداقل نسخه پشتیبانی می‌کند.
  4. نصب JavaScript: Livewire برای برخی از عملکردهای خود نیاز به JavaScript دارد. بنابراین، باید مطمئن شوید که JavaScript در پروژه شما فعال است و به درستی پیکربندی شده است.

با برآورده کردن این نیازمندی‌ها، شما می‌توانید Livewire را به پروژه Laravel خود اضافه کرده و از قابلیت‌های آن برای ایجاد رابط‌های کاربری پویا و بدون نیاز به فریم‌ورک‌های جاوااسکریپت پیچیده مانند Vue.js بهره‌برداری کنید.

آیا Livewire نیازمند نصب بسته‌های دیگری در پروژه Laravel است؟

Livewire به صورت مستقل کار می‌کند و نیازی به نصب بسته‌های دیگر در پروژه Laravel ندارد. با نصب بسته Livewir، تمامی وابستگی‌ها و کتابخانه‌های مورد نیاز Livewire به صورت خودکار نصب و پیکربندی می‌شوند.

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

بنابراین، برای استفاده از Livewire در پروژه Laravel، کافیست فقط بسته Livewire را نصب کنید و نیازی به نصب بسته‌های دیگر ندارید.

تعریف پروژه در livewire

برای تعریف پروژه در Livewire، شما نیاز به انجام مراحل زیر دارید:

ایجاد پروژه Laravel: ابتدا باید یک پروژه Laravel جدید ایجاد کنید. برای این کار، می‌توانید از دستور زیر در ترمینال یا دستورخط استفاده کنید:

laravel new my-livewire-project

این دستور یک پروژه Laravel جدید با نام “my-livewire-project” ایجاد می‌کند. شما می‌توانید نام موردنظر خود را برای پروژه انتخاب کنید

نصب بسته Livewire: بعد از ایجاد پروژه Laravel، باید بسته Livewire را نصب کنید. برای این کار، به دایرکتوری پروژه خود بروید و دستور زیر را اجرا کنید:

composer require livewire/livewire

پیکربندی Livewire: پس از نصب بسته Livewire، باید آن را در پروژه Laravel فعال کنید. برای این کار، به فایل `config/app.php` در پروژه خود بروید و به آرایه `providers` اضافه کنید:

`php
Livewire\LivewireServiceProvider::class,

۴. استفاده از کامپوننت Livewire: حالا می‌توانید از کامپوننت‌های Livewire در پروژه خود استفاده کنید. برای ایجاد یک کامپوننت جدید، می‌توانید از دستور زیر استفاده کنید:

php artisan make:livewire MyComponent

این دستور یک فایل کامپوننت با نام MyComponent.php در مسیر `app/Http/Livewire` ایجاد می‌کند. ۵. استفاده از کامپوننت Livewire در صفحات: برای استفاده از کامپوننت Livewire در صفحات Laravel، باید کامپوننت را به صفحه موردنظر خود پیوند دهید. برای این کار، به صفحه موردنظرتان بروید (مانند فایل Blade) و از دستور `@livewire` استفاده کنید. به عنوان مثال:

`php
@livewire('my-component')
```

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

ایجاد Viewدر Livewire

برای ایجاد و استفاده از Viewها در پروژه Livewire، می‌توانید از مراحل زیر پیروی کنید:

ایجاد فایل Blade: ابتدا باید یک فایل Blade برای نمایش دادن رابط کاربری خود ایجاد کنید. می‌توانید فایل Blade را در مسیر resources/views پروژه خود ایجاد کنید. به عنوان مثال، فایل my-view.blade.php را ایجاد کنید. استفاده از کامپوننت Livewire در فایل Blade: برای استفاده از کامپوننت Livewire در فایل Blade، باید کامپوننت را به صورت زیر به فایل Blade اضافه کنید:

<livewire:my-component />

در این مثال، `my-component` نام کامپوننت Livewire است که قبلاً ایجاد کرده‌اید.

شما می‌توانید نام کامپوننت خود را با توجه به نامی که برای کامپوننت خود انتخاب کرده‌اید، تغییر دهید. ۳. استفاده از داده‌ها در فایل Blade: شما می‌توانید به داده‌های مورد استفاده در کامپوننت Livewire دسترسی پیدا کنید و آن‌ها را در فایل Blade نمایش دهید. برای دسترسی به داده‌ها، از دستور `@livewire` و نام کامپوننت به همراه دستور `wire` استفاده کنید. به عنوان مثال:

<livewire:my-component />
<h1>{{ $wire('myData') }}</h1>

در این مثال،myData یکی از داده‌هایی است که در کامپوننت Livewire موجود است و شما آن را در فایل Blade نمایش می‌دهید. با انجام این مراحل، شما می‌توانید Viewهای خود را در پروژه Livewire ایجاد کنید و از آنها برای نمایش رابط‌های کاربری پویا استفاده کنید. خروجی:

آیا می‌توانم چندین کامپوننت Livewire را در یک فایل Blade استفاده کنم؟

بله، می‌توانید چندین کامپوننت Livewire را در یک فایل Blade استفاده کنید. برای این کار، می‌توانید هر کامپوننت را با استفاده از دستور <livewire:component-name /> در فایل Blade خود اضافه کنید.

در مثال زیر، فرض کنید دو کامپوننت Livewire به نام‌های Component1 و Component2 داریم و می‌خواهیم هر دو را در یک فایل Blade استفاده کنیم:

<livewire:component1 />
<livewire:component2 />

با اضافه کردن این کدها، هر دو کامپوننت در صفحه فعلی نمایش داده خواهند شد.

در صورت نیاز، همچنین می‌توانید به هر کامپوننت مورد نظر پارامترهای اضافی ارسال کنید. برای این کار، می‌توانید پارامترهای مورد نیاز را به عنوان ویژگی‌های HTML به دستور <livewire:component-name /> اضافه کنید. به عنوان مثال:

<livewire:component1 :param1="$value1" :param2="$value2" />
<livewire:component2 :param3="$value3" />

در این مثال، مقادیر $value1، $value2 و $value3 به عنوان پارامترهای param1، param2 و param3 به کامپوننت‌ها ارسال می‌شوند. به این ترتیب، شما می‌توانید چندین کامپوننت Livewire را در یک فایل Blade استفاده کنید و آنها را با یکدیگر ترکیب کنید.

تعریف property و method

در کامپوننت‌های Livewire، می‌توانید خصوصیت‌ها (Properties) و متدها (Methods) را تعریف کنید. خصوصیت‌ها داده‌هایی هستند که در کامپوننت ذخیره می‌شوند و متدها عملکردهایی هستند که می‌توانید در کامپوننت اجرا کنید.

برای تعریف خصوصیت‌ها و متدها در کامپوننت Livewire، شما باید از متدهای mount() و render() استفاده کنید. متد mount() برای اولین بار که کامپوننت لود می‌شود فراخوانی می‌شود و متد render() برای رندر کردن صفحه و نمایش اطلاعات به کاربر استفاده می‌شود.

در مثال زیر، تعریف یک خصوصیت و یک متد را نشان می‌دهیم:

<?php

namespace App\Http\Livewire;

use Livewire\Component;

class MyComponent extends Component
{
    public $name = 'John Doe'; // تعریف خصوصیت

    public function changeName()
    {
        $this->name = 'Jane Smith'; // تغییر مقدار خصوصیت
    }

    public function render()
    {
        return view('livewire.my-component');
    }
}

در این مثال، خصوصیت name به عنوان یک متغیر عمومی تعریف شده است و مقدار اولیه آن John Doe است. همچنین، متد changeName() تعریف شده است که مقدار خصوصیت name را به Jane Smith تغییر می‌دهد.

حالا می‌توانید از خصوصیت name در فایل Blade کامپوننت استفاده کنید و متد changeName() را اجرا کنید. به عنوان مثال:

<div> <h1>{{ $name }}</h1> <!-- نمایش مقدار خصوصیت name --> <button wire:click="changeName">Change Name</button> <!-- فراخوانی متد changeName() --> </div>

در این مثال، مقدار خصوصیت name با استفاده از دستور {{ $name }} نمایش داده می‌شود و با کلیک بر روی دکمه “Change Name”، متد changeName() فراخوانی می‌شود و مقدار خصوصیت name تغییر می‌کند.

با این روش، شما می‌توانید خصوصیت‌ها و متدهای بیشتری را در کامپوننت‌های Livewire تعریف کرده و از آنها در نمایش و برنامه‌ریزی رابط‌های کاربری خود استفاده کنید.

Bind کردن داده‌ها در Livewire

در کامپوننت‌های Livewire، می‌توانید داده‌ها را به صورت دوطرفه (Two-way binding) با رابط کاربری مرتبط کنید. این به شما امکان می‌دهد تا تغییراتی که توسط کاربر انجام می‌دهد را در داده‌ها دریافت کنید و همچنین تغییراتی که در داده‌ها اعمال می‌کنید را به صورت خودکار در رابط کاربری نمایش دهید.

برای بایند کردن داده‌ها در کامپوننت Livewire، شما باید از دستور wire:model استفاده کنید. این دستور را بر روی المنت‌های فرم و المنت‌هایی که مقدار آنها باید بروزرسانی شود، قرار دهید.

در مثال زیر، نحوه بایند کردن یک ورودی متنی (input) را نشان می‌دهیم:

<input type="text" wire:model="name" />

در این مثال، ورودی متنی مقدار name را با استفاده از دستور wire:model بایند می‌کند. هر تغییری که کاربر در ورودی انجام دهد، به صورت خودکار در خصوصیت name کامپوننت قرار می‌گیرد.

شما همچنین می‌توانید بر روی المنت‌های دیگری نیز از دستور wire:model استفاده کنید، مانند عناصر checkbox، radio buttons و select boxes.

همچنین، شما می‌توانید یک خصوصیت را به عنوان داده ورودی برای یک المنت استفاده کنید. به عنوان مثال:

<input type="text" wire:model="message" />
<button wire:click="sendMessage">Send</button

در این مثال، مقداری که کاربر در ورودی متنی وارد می‌کند، به صورت خودکار در خصوصیت message قرار می‌گیرد. همچنین، با کلیک بر روی دکمه “Send”، متد sendMessage() اجرا می‌شود و مقدار خصوصیت message به عنوان ورودی به آن ارسال می‌شود.

با استفاده از بایند کردن داده‌ها، شما می‌توانید تعاملات کاربر با رابط کاربری را در کامپوننت Livewire خود پیاده‌سازی کنید و تغییرات را به صورت خودکار دریافت و نمایش دهید.

اکشن‌ها Livewire

در کامپوننت‌های Livewire، اکشن‌ها (Actions) را می‌توانید استفاده کنید. اکشن‌ها، متدهایی هستند که توسط کاربر یا رویدادهایی که در رابط کاربری رخ می‌دهد، فراخوانی می‌شوند و عملکردهای خاصی را انجام می‌دهند.

برای تعریف اکشن‌ها در کامپوننت Livewire، شما باید از دستور public function استفاده کنید و نام متد را به عنوان یک اکشن تعریف کنید.

در مثال زیر، یک کامپوننت Livewire با یک اکشن به نام submitForm تعریف شده است:

<?php

namespace App\Http\Livewire;

use Livewire\Component;

class MyComponent extends Component
{
    public $name;

    public function submitForm()
    {
        // عملیات مورد نظر
    }

    public function render()
    {
        return view('livewire.my-component');
    }
}

در این مثال، اکشن submitForm() تعریف شده است. شما می‌توانید هرگونه عملیات مورد نظر خود را در این اکشن قرار دهید، مانند ذخیره داده‌ها، ارسال فرم، بروزرسانی اطلاعات و غیره.

حالا می‌توانید از اکشن submitForm در رابط کاربری خود استفاده کنید. به عنوان مثال:

<form wire:submit.prevent="submitForm">
    <input type="text" wire:model="name" />
    <button type="submit">Submit</button>
</form>

در این مثال، با فراخوانی اکشن submitForm در رویداد wire:submit.prevent فرم، این اکشن فراخوانی می‌شود. در این اکشن می‌توانید عملیات مربوط به ارسال فرم و پردازش داده‌ها را انجام دهید.

همچنین، شما می‌توانید اکشن‌ها را به رویدادهای دیگری نیز بایند کنید، مانند رویداد کلیک بر روی یک المنت یا رویداد تغییر مقدار یک المنت.

با استفاده از اکشن‌ها، شما می‌توانید عملیات‌های مختلف را در کامپوننت Livewire پیاده‌سازی کنید و با رویدادهای رابط کاربری ترکیب کنید.

می‌توانم اکشن‌ها را به رویدادهای دیگری نیز بایند کنم؟

بله، می‌توانید اکشن‌ها را به رویدادهای دیگری نیز بایند کنید. Livewire این امکان را به شما می‌دهد تا اکشن‌ها را به رویدادهای مختلفی مانند رویداد کلیک، تغییر مقدار، فوکوس و غیره بایند کنید.

برای بایند کردن اکشن‌ها به رویدادهای دیگر، شما می‌توانید از دستور wire:click، wire:change و سایر دستورات مشابه استفاده کنید.

در مثال زیر، یک اکشن به نام doSomething را به رویداد کلیک یک دکمه بایند می‌کنیم:

<button wire:click="doSomething">Click me</button>

در این مثال، هر بار که کاربر بر روی دکمه کلیک می‌کند، اکشن doSomething فراخوانی می‌شود.

همچنین، می‌توانید اکشن‌ها را به رویدادهای دیگری مانند wire:change (برای المنت‌های فرم)، wire:focus (وقتی المنت فوکوس می‌شود) و سایر رویدادها بایند کنید.

به عنوان مثال، برای بایند کردن یک اکشن به رویداد تغییر مقدار یک المنت، می‌توانید از دستور wire:change استفاده کنید:

<input type="text" wire:model="name" wire:change="doSomething" />

در این مثال، هر بار که مقدار المنت ورودی تغییر می‌کند، اکشن doSomething فراخوانی می‌شود.

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

استفاده از Modifire

در کامپوننت‌های Livewire، شما می‌توانید از مدیفایرها (Modifiers) برای تغییر رفتار و خصوصیات رویدادها و اکشن‌ها استفاده کنید. مدیفایرها امکان اعمال تغییراتی مانند تأخیر زمانی (Debounce)، محدود کردن تعداد فراخوانی (Throttle) و غیره را بر روی رویدادها و اکشن‌ها فراهم می‌کنند.

برای استفاده از مدیفایرها، شما باید مدیفایر مورد نظر را به رویداد یا اکشن اضافه کنید.

مدیفایر debounce به شما امکان می‌دهد تا زمان تأخیری را برای فراخوانی رویداد یا اکشن تعیین کنید. به عنوان مثال، اگر بخواهید فراخوانی یک اکشن به مدت ۵۰۰ میلی‌ثانیه بعد از اتمام تایپ کاربر انجام شود، می‌توانید از مدیفایر debounce:500 استفاده کنید:

<input type="text" wire:model.debounce.500ms="search" />

در این مثال، هر بار که کاربر متنی را در المنت وارد می‌کند، اکشن مورد نظر بعد از گذشت ۵۰۰ میلی‌ثانیه از اتمام تایپ فراخوانی می‌شود.

همچنین، مدیفایر throttle به شما امکان می‌دهد تا تعداد فراخوانی‌های رویداد یا اکشن را در یک بازه زمانی مشخص کنید. به عنوان مثال، اگر بخواهید حداکثر یک بار در هر ۱۰۰۰ میلی‌ثانیه رویداد را فراخوانی کنید، می‌توانید از مدیفایر throttle:1000ms استفاده کنید:

<button wire:click.throttle.1s="submitForm">Submit</button>

در این مثال، کاربر فقط یک بار در هر ۱۰۰۰ میلی‌ثانیه می‌تواند بر روی دکمه کلیک کند و اکشن submitForm فراخوانی شود.

شما همچنین می‌توانید مدیفایرهای once و stop را نیز استفاده کنید. مدیفایر once برای فراخوانی یکباره رویداد یا اکشن در طول چرخه زندگی کامپوننت مورد استفاده قرار می‌گیرد، و مدیفایر stop برای اجازه ندادن به رویداد یا اکشن به سایر رویدادها و اکشن‌ها اعمال می‌شود.

با استفاده از مدیفایرها، شما می‌توانید رفتار رویدادها و اکشن‌ها را به نیازهای خاص خودتان سفارشی کنید و کنترل بیشتری بر رویدادها و اکشن‌ها داشته باشید.

درخواست Ajax

برای بررسی درخواست Ajax در کامپوننت‌های Livewire، می‌توانید از متد wire:loading استفاده کنید. این متد به شما اجازه می‌دهد بررسی کنید که آیا درخواستی در حال ارسال است یا خیر.

به طور معمول، در صورتی که درخواست Ajax در حال ارسال باشد، می‌توانید نمایش یک نماد بارگذاری یا پیامی مانند “در حال بارگذاری” را نشان دهید. در غیر این صورت، محتوای مورد نظر را نمایش دهید.

در مثال زیر، یک کامپوننت Livewire با یک دکمه و یک المنت نمایش نتیجه وجود دارد. هنگام کلیک بر روی دکمه، یک درخواست Ajax ارسال می‌شود و متن “در حال بارگذاری…” نمایش داده می‌شود تا زمانی که پاسخ دریافت شود. پس از دریافت پاسخ، متن پاسخ نمایش داده می‌شود.

<div>
    <button wire:click="getData" wire:loading.attr="disabled">
        Load Data
    </button>

    <div wire:loading>
        در حال بارگذاری...
    </div>

    <div wire:loading.remove>
        نتیجه: {{ $result }}
    </div>
</div>

در این مثال، با استفاده از wire:loading روی دکمه، آن را غیرفعال می‌کنیم تا کاربر بتواند دکمه را در حالت بارگذاری غیرفعال کند. همچنین، با استفاده از wire:loading روی المنت نمایش نتیجه، ما مطمئن می‌شویم که آن تا زمان دریافت پاسخ مخفی باشد.

شما می‌توانید از متد wire:loading برای بررسی وضعیت درخواست Ajax استفاده کنید و به طور متناسب با آن رفتار کنید. خروجی:

چگونه می‌توانم از wire:loading برای بررسی وضعیت درخواست Ajax استفاده کنم؟

برای استفاده از wire:loading برای بررسی وضعیت درخواست Ajax در کامپوننت‌های Livewire، شما می‌توانید از آن به دو صورت مختلف استفاده کنید: به عنوان یک ویژگی (attribute) در المان‌ها و به عنوان یک دایرکتیو (directive) در المنت‌ها.

  1. استفاده به عنوان ویژگی (attribute):

در این رویکرد، شما می‌توانید wire:loading را به صورت یک ویژگی به المان‌ها اضافه کنید و وضعیت درخواست Ajax را بررسی کنید. مقدار ویژگی wire:loading به صورت true یا false برگشت داده می‌شود بسته به اینکه آیا درخواست Ajax در حال ارسال است یا خیر.

<div wire:loading>
    در حال بارگذاری...
</div>

<button wire:click="submit" wire:loading.attr="disabled">
    ارسال
</button>

در این مثال، هنگامی که درخواست Ajax در حال ارسال است، المنت <div> با ویژگی wire:loading نمایش داده می‌شود و پیام “در حال بارگذاری…” نمایش داده می‌شود. همچنین، دکمه با ویژگی wire:loading.attr="disabled" در حالت بارگذاری غیرفعال می‌شود.

  1. استفاده به عنوان دایرکتیو (directive):

در این رویکرد، شما می‌توانید wire:loading را به عنوان یک دایرکتیو در المنت‌ها استفاده کنید. این دایرکتیو به صورت شرطی المنت را نمایش یا عدم نمایش می‌دهد بسته به وضعیت درخواست Ajax.

<div>
    <button wire:click="submit">ارسال</button>

    <div wire:loading>
        در حال بارگذاری...
    </div>

    <div wire:loading.remove>
        پاسخ: {{ $response }}
    </div>
</div>

در این مثال، المنت <div> با دایرکتیو wire:loading هنگامی که درخواست Ajax در حال ارسال است، نمایش داده می‌شود و پیام “در حال بارگذاری…” را نشان می‌دهد. همچنین، المنت <div> دیگر با دایرکتیو wire:loading.remove هنگامی که درخواست Ajax در حال ارسال نیست، نمایش داده می‌شود و پاسخ دریافتی را نمایش می‌دهد.

با استفاده از wire:loading به عنوان ویژگی یا دایرکتیو، می‌توانید وضعیت درخواست Ajax را بررسی کرده و رفتارهای متفاوتی را بر اساس آن اعمال کنید.

جمع‌بندی: کاربرد livewire در لاراول چیست؟

در این سری مقالات آموزشی لاراول، Livewire را مورد بررسی قرار دادیم. از این مقاله می‌توانید یاد بگیرید که Livewire چیست و چه کاربردی دارد، چگونه کار می‌کند و با عناصر اصلی آن و نحوه کار با آن آشنا شوید. همچنین، در این مقاله به بررسی ساختار درخواست‌های Ajax ارسالی به سرور پرداخته‌ایم تا شما بتوانید بهتر فریم‌ورک Livewire در لاراول را درک کنید.

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

پوریا گودرز

پوریا گودرز هستم‌ علاقه مند به مباحث‌ و‌‌ مشکلات مربوط به تکنولوژی و فناوری. همچنین اندک آشنایی در زمینه گرافیک دارم. امیدوارم بتونم مشکلات شما رو در این مباحث حل کنم . انتقادات خود را از بخش نظرات با من در میان بگذارید :)

نوشته های مشابه

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

دکمه بازگشت به بالا