Facade là gì?

Chúng ta có thể hiểu Facade là mặt tiền và mặt trước của một tòa nhà hay bất cứ thứ gì. Tầm quan trọng của Facade là chúng có thể dễ nhận thấy và nổi bật hơn, tương tự như vậy, thì trong Laravel cũng có một khái niệm về Facade. Nhưng chúng ta không phải phát triển một tòa nhà trong Laravel mà chúng ta sẽ quản lý mã nguồn và xây dựng cú pháp dễ nhớ của hàm hoặc lớp thông qua Facade.

Trước khi, chúng ta đi sau hơn về khái niệm Facade trong Laravel, thì điều quan trọng nhất là chúng ta phải hiểu khái niệm hàm không tĩnh và hàm tĩnh trong PHP là gì.

Phương thức static 

Trong phương thức static, chúng ta không cần phải khởi tạo class thì mới có thể sử dụng được các hàm bên trong class đó. Phương thức static, chúng ta sử dụng dấu (::) khi truy cập hàm của một class:

<?php
class Calc {
    const GOLDEN_RATIO = '24.5';
}

echo Calc::GOLDEN_RATIO;

Các từ khóa như seft, staticparent được sử dụng để tham chiếu các thuộc tính hoặc phương thức trong một class.

<?php

class blogs {
    private const name = "ManhDanBlogs";

    public static function name() 
    {
        echo self::name;
    }
}

blogs::name();

Phương thức non-static

Trong phương thức non-static, chúng ta cần phải khởi tạo class thì mới có thể tham chiếu các thuộc tính hoặc phương thức trong một class.

<?php

class blogs {
    public function name($name)
    {
        echo $name;
    }
}

$test = new blogs;
$test->name('ManhDanBlogs');

Sau khi, chúng ta đã xem qua các khái niệm về phương thức staticnon-static, chúng ta sẽ đi sâu hơn về khái niệm Facade trong Laravel.

Laravel Facades

Facade cung cấp phương thức "static" để tương tác các class được khai báo bên trong service container. Laravel Facade service giống như "static proxies" cho các class bên dưới service container. Nó giúp cú pháp ngắn gọn, dễ hiểu hơn so với phương thức static truyền thống.

Ví dụ : Cache::get('key'); hay Publisher::publish($this); là những Facade.

Tới đây, chúng ta còn chần chừ gì nữa, mà không tiến hành xây dựng một Facade trong Laravel cho riêng mình.

Đầu tiên, chúng ta sẽ tạo một thư mục tên là Services trong thư mục app (tức là app/Services) trong project Laravel của bạn.

Bên trong thư mục này, chúng ta sẽ tạo một file PHP có tên là CustomServices. Bạn hãy mở file và chỉnh sửa như sau:

<?php
 
namespace App\Services;
 
class CustomServices {
    public function getVerificationCode($min = 10000, $max=99999)
    {
        return rand($min, $max);
    }
}

Tiếp theo, chúng ta sẽ đăng kí CustomServices trong service provider.

Bạn có thể tạo một service provider mới hoặc chỉ cần thêm CustomServices vào app/Providers/AppServiceProvider.php

public function register()
{
    $this->app->singleton('CustomServicesAlias', function ($app) {
        return new \App\Services\CustomServices;
    });
}

Bây giờ, chúng ta sẽ tạo một thư mục có tên là Facades trong thư mục app (tức là app/Facades) trong project Laravel của bạn.

Bên trong thư mục này, chúng ta sẽ tạo một file PHP có tên là CustomServicesFacade. Bạn hãy mở file và chỉnh sửa như sau:

<?php
 
namespace App\Facades;
 
use Illuminate\Support\Facades\Facade;
 
class CustomServicesFacade extends Facade
{
    protected static function getFacadeAccessor()
    {
        return 'CustomServicesAlias';
    }
}

Tiếp theo, chúng ta sẽ đăng kí alias cho CustomServicesFacade trong config/app.php. Bạn hãy mở file config/app.php và thêm CustomServicesFacade trong array aliases.

'aliases' => [
    ...
    'CustomServicesFacade' => App\Facades\CustomServicesFacade::class
],

Bây giờ, bạn đã sẵn sàng để sử dụng Custom Facade trong suốt project Laravel của bạn rồi. Với một ví dụ đơn giản trên, chúng ta đã thêm một đoạn mã nguồn của controller bằng cách sử dụng phương thức getVerificationCode thông qua CustomServicesFacade.

<?php

namespace App\Http\Controllers;

use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Foundation\Bus\DispatchesJobs;
use Illuminate\Foundation\Validation\ValidatesRequests;
use Illuminate\Routing\Controller as BaseController;
use CustomServicesFacade;

class Controller extends BaseController
{
    use AuthorizesRequests, DispatchesJobs, ValidatesRequests;

    public function getVerificationCode(Request $request)
    {
       $verificationCode = CustomServicesFacade::getVerificationCode();
       return $verificationCode;
    }
}

Tôi hy vọng bạn thích hướng dẫn này. Nếu bạn có bất kỳ câu hỏi nào hãy liên hệ với chúng tôi qua trang contact. Cảm ơn bạn.

CÓ THỂ BẠN QUAN TÂM

Laravel UI Password Reset Expired

Laravel UI Password Reset Expired

Trong thư viện laravel/ui, thì chức năng password reset dù cho token có hết hạn thì vẫn có truy cập vào trang password reset, đến khi bạn submit form thì mới thông báo là token đã hết hạn. Nhưng có mộ...

Laravel 9 REST API With Sanctum Authentication

Laravel 9 REST API With Sanctum Authentication

Laravel Sanctum Laravel Sanctum cung cấp một hệ thống authentication đơn giản cho các SPA, ứng dụng Mobile và API đơn giản sử dụng token. Sanctum cho phép ứng dụng của bạn phát hành các mã token...

Laravel Socialite Login With Google

Laravel Socialite Login With Google

Google Google là một công cụ tìm kiếm trên internet. Nó sử dụng một thuật toán độc quyền được thiết kế để truy xuất và sắp xếp các kết quả tìm kiếm nhằm cung cấp các nguồn dữ liệu đáng tin cậy và ph...

Laravel Upload File Using Trait

Laravel Upload File Using Trait

Hiện nay, đa số các dự án đều có chức năng upload file, nên tôi đã thử xây dựng một lớp Trait Upload File, để chúng ta dễ dàng sao chép qua các dự án khác để sử dụng, nhằm rút ngắn thời gian phát triể...

Integrating TinyMCE in Laravel 10 using Vite

Integrating TinyMCE in Laravel 10 using Vite

TinyMCE TinyMCE là một trình soạn thảo WYSIWYG được xây dựng trên nền tảng Javascript, được phát triển dưới dạng mã nguồn mở theo giấy phép MIT bởi Tiny Technologies Inc. TinyMCE cho phép ngư...

Efficient Laravel PDF Export for Large Datasets

Efficient Laravel PDF Export for Large Datasets

Xuất file PDF là một tính năng quan trọng của nhiều ứng dụng web, đặc biệt là các trang thương mại điện tử, giúp người dùng tạo và lưu trữ các bản báo cáo, hóa đơn, v.v.  Tuy nhiên, khi phải xử lý...

Laravel Has Many Through Eloquent Relationship

Laravel Has Many Through Eloquent Relationship

Has Many Through Relationship hơi phức tạp để hiểu một cách đơn giản, nó sẽ cung cấp cho chúng ta một con đường tắt để có thể truy cập dữ liệu của một quan hệ xa xôi thông qua một mối quan hệ trung gi...

Laravel Middlewares

Laravel Middlewares

Middleware cung cấp một cơ chế thuận tiện để lọc các yêu cầu HTTP gửi đến ứng dụng bạn. Nó là một lớp trung gian nằm giữa request và controller. Bạn có thể thêm các xử lý logic trước khi gửi đến contr...

Laravel Change Expire Time Cookie Remember

Laravel Change Expire Time Cookie Remember

Vấn đề Đôi khi, trang web của bạn chỉ muốn người dùng sử chức năng remembering users  trong 7 ngày hoặc là 30 ngày chẳng hạn. Nhưng Authentication của Laravel không cung cấp cho chúng ta tùy chọn đ...

ManhDanBlogs