您好,登錄后才能下訂單哦!
今天小編給大家分享一下Laravel使用技巧有哪些的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
如果我們有一個非常復雜的查詢構造器或原始 SQL語句,我們應該將此查詢移動到模型或倉庫中。
壞的:
<?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();
}
}
與上述第一點相關,我們應該有一個瘦控制器,然后我們應該將所有業務邏輯移動到單獨的服務類中。 所以控制器應該只有一個職責,希望我們可以在其他控制器中重用這個服務。
壞的:
<?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)
{
// ...
}
}
使用 Eloquent 進行查詢更具可讀性,避免 SQL 注入,并且易于維護。
壞的:
<?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();
我們應該考慮將可重用的邏輯/組件部分移動到單獨的地方。
在 blade 模板中,我們可以使用組件來重用前端部分。在服務器中,我們可以將邏輯移動到一個單獨的服務類、Eloquent scope作用域,甚至可以創建我們自己的包。
<!DOCTYPE html>
<html>
<head>
<title>DRY</title>
</head>
<body>
<h2>Custom Calendar</h2>
<x-custom-calendar>
</body>
</html>
盡管在 blade 模板中執行查詢是可行的, 但最好不要這么做。
壞的。 將會造成 N+1 問題。
@foreach (User::all() as $user)
{{ $user->email }}
@endforeach
好的:
$users = User::all(); // Server Query
@foreach ($users as $user)
{{ $user->email }}
@endforeach
如果我們有一些復雜而冗長的邏輯/查詢,那么我們應該考慮使用數據庫事務。通過使用此功能,我們可以在需要時輕松回滾數據庫,以確保我們的數據不會保存到數據庫中,因此我們確信我們的數據是可靠的。
<?php
public function store(Request $request)
{
DB::beginTransaction();
$user = User::create();
$response = app('service')->create($user);
if (!$response) {
DB::rollback();
return;
}
// ...
DB::commit();
}
我們不應該在代碼/控制器中硬編碼任何文本。這樣以后很容易維護和擴展。如果我們想向用戶顯示消息,我們可以使用翻譯,模型/類中的常量來設置任何值或配置文件來保存我們的配置。
trans('user.created'); // 'User Successfully Created'
$types = Product::TYPES; // Const in a Class/Model
以上就是“Laravel使用技巧有哪些”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。