Home>Article>PHP Framework> Some tips when using Laravel

As the title indicates, when the child model is updated, the timestamp of the parent model can be triggered. For exampleCommentbelongs toPost, sometimes it is useful to update the child model causing the parent model timestamp to be updated. For example, when theCommentmodel is updated, you want to automatically trigger an update of theUpdated_attimestamp of the parentPostmodel.EloquentMake it easy, just add atouchattribute containing the name of the child model relationship.
belongsTo('App\Post'); } }
When using preloading, you can get the specified columns from the relationship.
$users = App\Book::with('author:id,name')->get();
You can useAuth::once()to authenticate the user for a single request, this method will not useCookieSession. This means that this method may be useful for building statelessAPI.
if (Auth::once($credentials)) { // }
You can not only use theredirect()method with user-specific URLs or routes, It can also be used in methods with parameters in the controller.
return redirect()->action('SomeController@method', ['param' => $value]);
withDefault()to avoid errors in relationshipsWhen a relationship is called, a fatal error occurs if it does not exist Errors, such as$post->user->name, can be avoided usingwithDefault().
/** 获取文章作者 */ public function user() { return $this->belongsTo('App\User')->withDefault(); }
$loopvariablesare inforeachofblade, Even in two loops, you can still get the parent variable by using the$loopvariable.
@foreach ($users as $user) @foreach ($user->posts as $post) @if ($loop->parent->first) This is first iteration of the parent loop. @endif @endforeach @endforeach
After executing theEloqumentquery, you can usemap()to modify the rows.
$users = User::where('role_id', 1)->get()->map(function (User $user) { $user->some_column = some_function($user); return $user; });
dd()Add$test->dd() at the end ofEloqument, instead ofdd($result).
// 优化前 $users = User::where('name', 'Taylor')->get(); dd($users); // 优化后 $users = User::where('name', 'Taylor')->get()->dd();
If there is ahasMany()relationship and you want to save many subclass objects from the parent class object, you can usesaveMany()to achieve the effect you want.
$post = Post::find(1); $post->comments()->saveMany([ new Comment(['message' => 'First comment']), new Comment(['message' => 'Second comment']), ]);
Model::all()When you useEloqument'sModel::all( ), you can specify the columns to be returned.
$users = User::all(['id', 'name', 'email']);
@authinYou can use the@authdirective instead ofifstatement to check if the user is authenticated.
@if(auth()->user()) // The user is authenticated. @endif
@auth // The user is authenticated. @endauth
If you useMailablesto send your emails, you can preview them without sending them.
Route::get('/mailable', function () { $invoice = App\Invoice::find(1); return new App\Mail\InvoicePaid($invoice); });
hasManyIn thehasMany()relationship ofEloquentyou can filter out Records with n number of sub-records.
// Author -> hasMany(Book::class) $authors = Author::has('books', '>', 5)->get();
If the records use soft deletion, then you can restore multiple soft deleted records at one time.
Post::withTrashed()->where('author_id', 1)->restore();
The migration file not only hastimestamps()timestamps, but alsotimestampsTz()with time zone timestamp.
Schema::create('employees', function (Blueprint $table) { $table->increments('id'); $table->string('name'); $table->string('email'); $table->timestampsTz(); });
Did you know you can also check if a view file exists?
if (view()->exists('custom.page')) { // Load the view }
In the routing file, you can create a group for a routing group and specify specific middleware for it.
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'); }); });
EloquentwhereDay(),whereMonth(),whereYear(),whereDate(),whereTime()These methods are all methods for checking dates inEloquent.
$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();
orderBy() in theEloquentrelationshipYou can specify # directly in theEloquentrelationship ##orderBy().
public function products() { return $this->hasMany(Product::class); } public function productsByName() { return $this->hasMany(Product::class)->orderBy('name'); }20: Unsigned integer
For migrated foreign keys, do not use
integer(), but useunsignedInteger()or It isinteger()->unsigned(), otherwise a series of errors will occur.
Schema::create('employees', function (Blueprint $table) { $table->unsignedInteger('company_id'); $table->foreign('company_id')->references('id')->on('companies'); });For more Laravel related technical articles, please visit the
Laravel Tutorialcolumn to learn!
The above is the detailed content of Some tips when using Laravel. For more information, please follow other related articles on the PHP Chinese website!