如標題所示,在子模型更新時,可以觸發父模型的時間戳記。例如 Comment
屬於 Post
,有時更新子模型導致更新父模型時間戳非常有用。例如,當 Comment
模型被更新時,您要自動觸發父級 Post
模型的 updated_at
時間戳記的更新。 Eloquent
讓它變得簡單,只需新增一個包含子模型關係名稱的 touch
屬性。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Comment extends Model { /** * 涉及到的所有关联关系。 * * @var array */ protected $touches = ['post']; /** * 获取评论所属的文章。 */ public function post() { return $this->belongsTo('App\Post'); } }
在使用預先載入時,可以從關係中取得指定的列。
$users = App\Book::with('author:id,name')->get();
你可以使用Auth::once()
來為單一請求驗證使用者的身份,此方法不會使用Cookie
會話。這意味著此方法可能有助於建立無狀態 API 。
if (Auth::once($credentials)) { // }
你不僅可以將redirect()
方法用於用戶特定的URL 或路由中,也可以用於控制器中帶有參數的方法。
return redirect()->action('SomeController@method', ['param' => $value]);
withDefault()
避免在關係中出現的錯誤當一個關係被呼叫時,如果它不存在,則會出現致命的錯誤,例如$post->user->name
,可以使用withDefault()
來避免。
/** 获取文章作者 */ public function user() { return $this->belongsTo('App\User')->withDefault(); }
$loop
變數在blade
的foreach
中,即使在兩個循環中,依然可以透過使用$loop
變數來取得父級變數。
@foreach ($users as $user) @foreach ($user->posts as $post) @if ($loop->parent->first) This is first iteration of the parent loop. @endif @endforeach @endforeach
在執行 Eloqument
查詢後,你可以使用 map()
來修改行。
$users = User::where('role_id', 1)->get()->map(function (User $user) { $user->some_column = some_function($user); return $user; });
dd()
在Eloqument
的最後加上$test->dd()
,來代替dd($result)
。
// 优化前 $users = User::where('name', 'Taylor')->get(); dd($users); // 优化后 $users = User::where('name', 'Taylor')->get()->dd();
如果有hasMany()
關聯關係,和想要從父類別物件中保存許多子類別對象,可以使用saveMany()
來達到你想要的效果。
$post = Post::find(1); $post->comments()->saveMany([ new Comment(['message' => 'First comment']), new Comment(['message' => 'Second comment']), ]);
Model::all()
中指定列當你使用Eloqument
的Model::all( )
時,你可以指定要傳回的列。
$users = User::all(['id', 'name', 'email']);
Blade
中的@auth
你可以使用@auth
指令來取代if
語句來檢查使用者是否經過身份驗證。
@if(auth()->user()) // The user is authenticated. @endif
@auth // The user is authenticated. @endauth
如果你使用Mailables 來發送你的郵件,你可以預覽它們而不發送出去。
Route::get('/mailable', function () { $invoice = App\Invoice::find(1); return new App\Mail\InvoicePaid($invoice); });
hasMany
的特定檢查在Eloquent
的hasMany()
關係中,你可以篩選出具有n 個子記錄數量的記錄。
// Author -> hasMany(Book::class) $authors = Author::has('books', '>', 5)->get();
如果記錄使用了軟體刪除,那麼你就可以一次還原多筆軟刪除記錄。
Post::withTrashed()->where('author_id', 1)->restore();
遷移檔案不只有timestamps()
時間戳,還有timestampsTz()
帶有時區的時間戳。
Schema::create('employees', function (Blueprint $table) { $table->increments('id'); $table->string('name'); $table->string('email'); $table->timestampsTz(); });
你知道還可以檢查視圖檔案是否存在嗎?
if (view()->exists('custom.page')) { // Load the view }
在路由檔案中,你可以為一個路由群組建立一個群組,也可以為其指定特定的中間件。
Route::group(['prefix' => 'account', 'as' => 'account.'], function() { Route::get('login', 'AccountController@login'); Route::get('register', 'AccountController@register'); Route::group(['middleware' => 'auth'], function() { Route::get('edit', 'AccountController@edit'); }); });
Eloquent
中的日期時間方法whereDay()
, whereMonth()
, whereYear()
, whereDate()
, whereTime()
這些方法皆為Eloquent
中檢查日期的方法。
$products = Product::whereDate('created_at', '2018-01-31')->get(); $products = Product::whereMonth('created_at', '12')->get(); $products = Product::whereDay('created_at', '31')->get(); $products = Product::whereYear('created_at', date('Y'))->get(); $products = Product::whereTime('created_at', '=', '14:13:58')->get();
Eloquent
關係中使用orderBy()
你可以在Eloquent
關係中直接指定orderBy()
。
public function products() { return $this->hasMany(Product::class); } public function productsByName() { return $this->hasMany(Product::class)->orderBy('name'); }
對於遷移的外鍵,不要使用integer()
, 而是使用unsignedInteger()
或者是integer()->unsigned()
,否則將會出現一連串的錯誤。
Schema::create('employees', function (Blueprint $table) { $table->unsignedInteger('company_id'); $table->foreign('company_id')->references('id')->on('companies'); });
更多Laravel相關技術文章,請造訪Laravel教學專欄進行學習!
以上是使用Laravel時的一些小技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!