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

Some tips when using Laravel

步履不停
Release: 2019-06-28 16:12:48
Original
3756 people have browsed it

Some tips when using Laravel

01: Trigger the timestamp of the parent

As the title indicates, when the child model is updated, the timestamp of the parent model can be triggered. For example Comment belongs to Post, sometimes it is useful to update the child model causing the parent model timestamp to be updated. For example, when the Comment model is updated, you want to automatically trigger an update of the Updated_at timestamp of the parent Post model. Eloquent Make it easy, just add a touch attribute containing the name of the child model relationship.

<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Comment extends Model
{
    /**
     * 涉及到的所有关联关系。
     *
     * @var array
     */
    protected $touches = [&#39;post&#39;];
    /**
     * 获取评论所属的文章。
     */
    public function post()
    {
        return $this->belongsTo('App\Post');
    }
}
Copy after login

02: Preloading exact columns

When using preloading, you can get the specified columns from the relationship.

$users = App\Book::with('author:id,name')->get();
Copy after login

03: Authenticate the user for a single request

You can use Auth::once() to authenticate the user for a single request, this method will not use Cookie Session. This means that this method may be useful for building stateless API.

if (Auth::once($credentials)) {
    //
}
Copy after login

04: Redirect to a controller method with parameters

You can not only use the redirect() 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]);
Copy after login

05: How to use withDefault() to avoid errors in relationships

When a relationship is called, a fatal error occurs if it does not exist Errors, such as $post->user->name, can be avoided using withDefault().

/** 获取文章作者 */ 
public function user() 
{     
    return $this->belongsTo('App\User')->withDefault(); 
}
Copy after login

06: In the template, two parallel $loop variables

are in foreach of blade, Even in two loops, you can still get the parent variable by using the $loop variable.

@foreach ($users as $user)     
    @foreach ($user->posts as $post)         
        @if ($loop->parent->first)             
            This is first iteration of the parent loop.         
        @endif     
    @endforeach 
@endforeach
Copy after login

07: Modify query results

After executing the Eloqument query, you can use map() to modify the rows.

$users = User::where('role_id', 1)->get()->map(function (User $user) {
    $user->some_column = some_function($user);
    return $user;
});
Copy after login

08: Easily use dd()

Add $test->dd() at the end of Eloqument , instead of dd($result).

// 优化前
$users = User::where('name', 'Taylor')->get();
dd($users);
// 优化后
$users = User::where('name', 'Taylor')->get()->dd();
Copy after login

09: Use hasMany to saveMany.

If there is a hasMany() relationship and you want to save many subclass objects from the parent class object, you can use saveMany() to achieve the effect you want.

$post = Post::find(1);
$post->comments()->saveMany([
    new Comment(['message' => 'First comment']),
    new Comment(['message' => 'Second comment']),
]);
Copy after login

10: Specifying columns in Model::all()

When you use Eloqument's Model::all( ), you can specify the columns to be returned.

$users = User::all(['id', 'name', 'email']);
Copy after login

11: @auth in

Blade

You can use the @auth directive instead of if statement to check if the user is authenticated.

Typical method:
@if(auth()->user())     // The user is authenticated. @endif
Copy after login
Short method:
@auth    
 // The user is authenticated. 
@endauth
Copy after login

12: Preview email without sending

If you use Mailables to 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);
});
Copy after login

13: Specific check for hasMany

In the hasMany() relationship of Eloquent you can filter out Records with n number of sub-records.

// Author -> hasMany(Book::class) 
$authors = Author::has('books', '>', 5)->get();
Copy after login

14: Restore multiple soft deletions

If the records use soft deletion, then you can restore multiple soft deleted records at one time.

Post::withTrashed()->where('author_id', 1)->restore();
Copy after login

15: Migration column with time zone

The migration file not only has timestamps() timestamps, but also timestampsTz() with time zone timestamp.

Schema::create('employees', function (Blueprint $table) {
    $table->increments('id');
    $table->string('name');
    $table->string('email');
    $table->timestampsTz();
});
Copy after login

16: Does the view file exist?

Did you know you can also check if a view file exists?

if (view()->exists('custom.page')) {
    // Load the view
}
Copy after login

17: Routing groups in groups

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');     
    });
});
Copy after login

18: Date and time methods in Eloquent

whereDay() , whereMonth() , whereYear() , whereDate() , whereTime() These methods are all methods for checking dates in 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();
Copy after login

19: Using orderBy() in the Eloquent relationship

You can specify # directly in the Eloquent relationship ##orderBy() .

public function products()
{
    return $this->hasMany(Product::class);
}
public function productsByName()
{
    return $this->hasMany(Product::class)->orderBy('name');
}
Copy after login
20: Unsigned integer

For migrated foreign keys, do not use

integer(), but use unsignedInteger() or It is integer()->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');     
});
Copy after login
For more Laravel related technical articles, please visit the

Laravel Tutorial column 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!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template