Dev to webs {Coding…}

เรียนรู้การพัฒนาซอฟเวอร์ เพื่อความรู้ที่ยั่งยืน

บทที่ 1: แนะนำ Livewire

Livewire เป็นเฟรมเวิร์กที่ทำงานร่วมกับ Laravel สำหรับการพัฒนา Frontend ที่ไม่ต้องใช้ JavaScript มากนัก สามารถเขียนโค้ดทั้ง Frontend และ Backend ด้วย PHP ได้ ทำให้การพัฒนาเป็นไปอย่างรวดเร็ว โดยที่เรายังคงได้ประสบการณ์การใช้งานที่เป็น Interactive แบบ JavaScript

Livewire ทำงานผ่าน Component ที่ใช้แสดงผลและรับข้อมูลจากผู้ใช้ โดยแต่ละ Component จะเป็นเหมือนส่วนหนึ่งของ UI ที่มีการโต้ตอบได้ เช่น ฟอร์มกรอกข้อมูลหรือการคลิกปุ่ม เป็นต้น

ตัวอย่างโค้ด

ในการเริ่มต้นใช้งาน Livewire คุณต้องติดตั้ง Livewire ก่อน และสร้าง Component แรกดังนี้:

  1. ติดตั้ง Livewire ใช้คำสั่งต่อไปนี้ใน Terminal เพื่อเพิ่ม Livewire เข้ากับโปรเจค Laravel ของคุณ:
composer require livewire/livewire

2. สร้าง Component แรก หลังจากติดตั้งแล้ว คุณสามารถสร้าง Component ได้โดยใช้คำสั่งนี้:

php artisan make:livewire HelloWorld

คำสั่งนี้จะสร้างไฟล์ใหม่ 2 ไฟล์:

  • HelloWorld.php (ในโฟลเดอร์ app/Http/Livewire) – จัดการ Backend Logic ของ Component
  • hello-world.blade.php (ในโฟลเดอร์ resources/views/livewire) – จัดการ Frontend View ของ Component

3. การเขียนโค้ดใน Component ในไฟล์ HelloWorld.php ให้เพิ่มฟังก์ชันเพื่อแสดงข้อความที่ต้องการ:

<?php

namespace App\Http\Livewire;

use Livewire\Component;

class HelloWorld extends Component
{
    public $name = 'World';

    public function render()
    {
        return view('livewire.hello-world');
    }
}

ในไฟล์ hello-world.blade.php ให้เขียน HTML ที่ใช้แสดงผลข้อมูลจาก Component:

<div>
    <h1>Hello, {{ $name }}!</h1>
    <input type="text" wire:model="name" placeholder="Enter your name">
</div>

4. การเรียกใช้ Component ใน Blade Template หลังจากสร้าง Component แล้ว คุณสามารถเรียกใช้ได้โดยเพิ่มโค้ดต่อไปนี้ใน Blade Template ที่คุณต้องการให้แสดงผล:

@livewire('hello-world')

การนำไปใช้งาน

Livewire เหมาะสำหรับการพัฒนาเว็บที่ต้องการประสบการณ์การใช้งานแบบ Interactive โดยไม่ต้องใช้ JavaScript มากมาย เช่น:

  • การทำฟอร์มที่มีการตรวจสอบข้อมูลทันที
  • การอัปเดตข้อมูลแบบ Real-Time
  • การสร้าง UI Components ที่สามารถโต้ตอบได้

Livewire ช่วยให้การพัฒนาทำได้ง่ายขึ้นโดยการใช้ PHP เป็นหลัก ลดความซับซ้อนในการเชื่อมต่อระหว่าง Frontend และ Backend