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

Integrating AI Assistant with CKEditor 5 in Laravel using Vite

Integrating AI Assistant with CKEditor 5 in Laravel using Vite

OpenAI OpenAI là một công ty nghiên cứu và triển khai trí tuệ nhân tạo, nổi tiếng với việc phát triển các mô hình AI tiên tiến. Mục tiêu của OpenAI là đảm bảo rằng trí tuệ nhân tạo tổng quát (AGI...

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ộ...

Encrypted HTTP Live Streaming with Laravel FFMpeg

Encrypted HTTP Live Streaming with Laravel FFMpeg

HTTP Live Streaming (HLS)  HTTP Live Streaming (HLS) là một trong những giao thức phát trực tuyến video được sử dụng rộng rãi nhất . Mặc dù nó được gọi là HTTP "live" streaming, nhưng nó được sử dụn...

Implementing Private User Folders with elFinder in Laravel

Implementing Private User Folders with elFinder in Laravel

elFinder elFinder là một trình quản lý tập tin mã nguồn mở dành cho web, được viết bằng JavaScript sử dụng jQuery UI. elFinder được phát triển dựa trên cảm hứng từ sự tiện lợi và đơn giản của chư...

Implementing Private User Folders with CKFinder in Laravel

Implementing Private User Folders with CKFinder in Laravel

CKFinder 3 CKFinder 3 là trình quản lý tập tin được tích hợp với CKEditor 4 và CKEditor 5. Nó giúp bạn dễ dàng đưa các tập tin và hình ảnh vào nội dung của Editor một cách an toàn. Đây là một tín...

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ư...

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 Facebook

Laravel Socialite Login With Facebook

Ngoài xác thực dựa trên biểu mẫu điển hình, Laravel cũng cung cấp một cách đơn giản và thuận tiện để sử dụng Laravel Socialite để xác thực với các nhà cung cấp OAuth. Socialite hiện hỗ trợ xác thực qu...

Laravel Validate Video Duration

Laravel Validate Video Duration

Đôi khi trong dự án, chúng ta cần xác định thời lượng video được phép upload lên server. Nhưng rất tiếc, Laravel không cung cấp validate xác định thời lượng video để chúng ta thực hiện được. Vì vậy, t...

ManhDanBlogs