溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Laravel使用技巧有哪些

發(fā)布時(shí)間:2023-01-04 09:05:24 來源:億速云 閱讀:92 作者:iii 欄目:編程語言

今天小編給大家分享一下Laravel使用技巧有哪些的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

1.胖模型,瘦控制器

如果我們有一個非常復(fù)雜的查詢構(gòu)造器或原始 SQL語句,我們應(yīng)該將此查詢移動到模型或倉庫中。

壞的:

<?php
public function index()
{
    $partners = Partner::where('email_verified_at', '!=', null)
        ->with(['products' => function ($q) {
            $q->whereDate('created_at', now());
        }])
        ->get();

    return view('index', ['partners' => $partners]);
}

好的:

<?php
public function index()
{
    return view('index', ['partners' => $this->partner->newProducts()]);
}

class Partner extends Model
{
    public function newProducts()
    {
        return $this->where('email_verified_at', '!=', null)
            ->with(['products' => function ($q) {
                $q->whereDate('created_at', now());
            }])
            ->get();
    }
}

2.服務(wù)類中的業(yè)務(wù)邏輯

與上述第一點(diǎn)相關(guān),我們應(yīng)該有一個瘦控制器,然后我們應(yīng)該將所有業(yè)務(wù)邏輯移動到單獨(dú)的服務(wù)類中。 所以控制器應(yīng)該只有一個職責(zé),希望我們可以在其他控制器中重用這個服務(wù)。

壞的:

<?php
public function store(Request $request)
{
    $user = User::create();

    $user->update(['last_login' => now()]);

    dispatch(new UserCreated($user));

    // ...
}

好的:

<?php
public function store(Request $request)
{
    $this->userService->create($request);

    ....
}

class UserService
{
    public function create($request)
    {
       // ...
    }
}

3.Eloquent 查詢優(yōu)于原生 SQL 語句。

使用 Eloquent 進(jìn)行查詢更具可讀性,避免 SQL 注入,并且易于維護(hù)。

壞的:

<?php
SELECT *
FROM `articles`
WHERE EXISTS (SELECT *
              FROM `users`
              WHERE `articles`.`user_id` = `users`.`id`
              AND EXISTS (SELECT *
                          FROM `profiles`
                          WHERE `profiles`.`user_id` = `users`.`id`) 
              AND `users`.`deleted_at` IS NULL)
AND `verified` = '1'
AND `active` = '1'
ORDER BY `created_at` DESC

好的:

<?php
Article::has('user.profile')->verified()->latest()->get();

4.DRY (Don’t Repeat Yourself)

我們應(yīng)該考慮將可重用的邏輯/組件部分移動到單獨(dú)的地方。
在 blade 模板中,我們可以使用組件來重用前端部分。在服務(wù)器中,我們可以將邏輯移動到一個單獨(dú)的服務(wù)類、Eloquent scope作用域,甚至可以創(chuàng)建我們自己的包。

<!DOCTYPE html>
<html>
<head>
<title>DRY</title>
</head>
<body>

<h2>Custom Calendar</h2>

<x-custom-calendar>

</body>
</html>

5.不要在 Blade 模板中執(zhí)行查詢

盡管在 blade 模板中執(zhí)行查詢是可行的, 但最好不要這么做。

壞的。 將會造成 N+1 問題。

@foreach (User::all() as $user)
    {{ $user->email }}
@endforeach

好的:

$users = User::all(); // Server Query
@foreach ($users as $user)
    {{ $user->email }}
@endforeach

6.使用數(shù)據(jù)庫事務(wù)

如果我們有一些復(fù)雜而冗長的邏輯/查詢,那么我們應(yīng)該考慮使用數(shù)據(jù)庫事務(wù)。通過使用此功能,我們可以在需要時(shí)輕松回滾數(shù)據(jù)庫,以確保我們的數(shù)據(jù)不會保存到數(shù)據(jù)庫中,因此我們確信我們的數(shù)據(jù)是可靠的。

<?php
public function store(Request $request)
{
    DB::beginTransaction();
    $user = User::create();
    $response = app('service')->create($user);

    if (!$response) {
      DB::rollback();
      return;
    }
    // ...
    DB::commit();
 }

7.不要硬編碼文本

我們不應(yīng)該在代碼/控制器中硬編碼任何文本。這樣以后很容易維護(hù)和擴(kuò)展。如果我們想向用戶顯示消息,我們可以使用翻譯,模型/類中的常量來設(shè)置任何值或配置文件來保存我們的配置。

trans('user.created'); // 'User Successfully Created'
$types = Product::TYPES; // Const in a Class/Model

以上就是“Laravel使用技巧有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI