7 điều bạn cần biết để tận dụng tối đa Laravel Model

15:38 16-06-2020BKAP Media

Khi mới bắt đầu code với Laravel, mình cảm thấy có rất nhiều thứ có thể thực hiện tốt hơn khi sử dụng với Model.Sau một thời gian code với Laravel Model và tìm hiểu thì mình thấy một số điều thú vị mà bạn có thể sử dụng Model một cách dễ dàng.

Trong bài viết này mình sẽ cung cấp cho các bạn 7 lời khuyên mà mọi người sử dụng Laravel nên biết để tận dụng tối đa Model.

1: Cách tạo Model bằng command

Khi tạo một Model thông qua command, bạn có thể chỉ định thư mục Model sẽ được tạo. Việc của bạn cần làm là nhập tên thư mục lưu Model ở phía trước tên của Model. Điều này thực sự hữu ích khi bạn muốn lưu Model ở thư mục riêng thay vì mặc định lưu ở thư mục app

php artisan make:model Models/Product

2: Casting attributes

Thuộc tính $casts cung cấp một phương thức convert attributes thành các kiểu dữ liệu khác nhau khá tiện lợi. Thuộc tính $casts là một mảng có key là tên của attribute được cast, còn giá trị là kiểu dữ liệu bạn muốn cast. Các kiểu dữ liệu để cast được hỗ trợ bao gồm: integer, real, float, double, string, boolean, object, array, collection, date, datetime, và timestamp.

Ví dụ, hãy cast attribute is_admin được lưu trong database là integer (0 hoặc 1) thành giá trị boolean:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * The attributes that should be casted to native types.

     *

     * @var  array

     */

    protected $casts = [

        'is_admin' => 'boolean',

    ];

}

 

Bây giờ, attribute is_admin sẽ luôn luôn được cast thành boolean khi bạn truy cập nó, thậm chí nếu giá trị nó được lưu trong database là kiểu integer:

1

2

3

4

5

6

7

 

$user = App\User::find(1);

 

if ($user->is_admin) {

    //

}

 

3: Visibility

Sẽ có lúc bạn muốn giới hạn attributes như password không được hiển thị trong kết quả array hay JSON sau khi convert. Để làm được điều đó, thêm vào thuộc tính $hiddenvào trong model: Để khai báo một accessor, tạo một hàm getFooAttribute trong model với Foo là tên của cột bạn muốn truy cập sử dụng kiểu “camel”. Ở ví dụ này, chúng ta sẽ khai báo một accessor cho first_name. Accessor sẽ tự động được gọi bởi Eloquent khi lấy giá trị của first_name attribute:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * The attributes that should be hidden for arrays.

     *

     * @var  array

     */

    protected $hidden = ['password'];

}

 

Một cách khác, bạn có thể sử dụng thuộc tính visible để định nghĩa một white-list của những thuộc tính đó được bao gồm trong mảng của model và JSON representation. Tất cả các thuộc tính khác sẽ bị hidden khi model được convert thành mảng hoặc JSON:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * The attributes that should be visible in arrays.

     *

     * @var  array

     */

    protected $visible = ['first_name', 'last_name'];

}

 

Điều này hoạt động giống như các thuộc tính $fillable và $guarded

4: Accessors

Để khai báo một accessor, tạo một hàm getFooAttribute trong model với Foo là tên của cột bạn muốn truy cập sử dụng kiểu “camel”. Ở ví dụ này, chúng ta sẽ khai báo một accessor cho first_name. Accessor sẽ tự động được gọi bởi Eloquent khi lấy giá trị củafirst_name attribute:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * Get the user's first name.

     *

     * @param    string  $value

     * @return  string

     */

    public function getFirstNameAttribute($value)

    {

        return ucfirst($value);

    }

}

 

Như bạn thấy, giá trị gốc của column được truyền vào accessor, cho phép bạn thay đổi và trả về giá trị. Để lấy gía trị này, chỉ cần truyền vào tên attribute là first_name trong model instance:

 

1

2

3

4

5

 

$user = App\User::find(1);

 

$firstName = $user->first_name;

 

5: Mutator

Để khai báo một mutator, khai báo một hàm setFooAttribute trong model Foo là tên của cột theo “studly”. Vì vậy, lần nữa, định nghĩa một mutator cho thuộc tính first_name. Mutator sẽ được tự động gọi khi chúng ta set giá trị của thuộc tính first_name trong model:

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * Set the user's first name.

     *

     * @param    string  $value

     * @return  void

     */

    public function setFirstNameAttribute($value)

    {

        $this->attributes['first_name'] = strtolower($value);

    }

}

 

Mutator sẽ nhận giá trị được gán vào, cho phép bạn thay đổi tuỳ ý trong thuộc tính $attributes của Eloquent model. Ví dụ, chúng ta có thể gán giá trị thuộc tính first_namecho Sally:

1

2

3

4

5

 

$user = App\User::find(1);

 

$user->first_name = 'Sally';

 

6: Appending values

Thỉnh thoảng, khi casting models thành array hoặc JSON, bạn cũng có thể thêm vào thuộc tính mà không có trường lưu trong database. Để làm thế, đầu tiện cần phải khai báo một accessor:

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * Get the administrator flag for the user.

     *

     * @return  bool

     */

    public function getIsAdminAttribute()

    {

        return $this->attributes['admin'] == 'yes';

    }

}

 

Khi đã tạo được accessor, thêm vào tên của attribute vào thuộc tính appends trong model. Chú ý là tên của attribute là theo kiểu “snake case”, mặc dù accessor được xác định bằng kiểu “camel case”:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

 

<?php

 

namespace App;

 

use Illuminate\Database\Eloquent\Model;

 

class User extends Model

{

    /**

     * The accessors to append to the model's array form.

     *

     * @var  array

     */

    protected $appends = ['is_admin'];

}

 

Khi mà attribute được thêm vào trong danh sách appends, nó sẽ được thêm vào khi convert thành thành array hay JSON. Attribute trong mảng appends cũng sẽ tuần tự theo cấu hình visible và hidden trong model.

7: Touches

Khi một Model có quan hệ beLongsTo hoặc beLongsToMany với một Model khác, ví dụ một Comment thuộc về một Blog, trường hợp này rất hữu ích khi cập nhật timestapcủa cha khi con được cập nhật.Điều này có thể thực hiện bằng cách thêm vào mối quan hệ thuộc tính $touches:

1

2

3

4

5

6

7

8

9

10

11

 

class Comment extends Model

{

    protected $touches = ['blog'];

 

    public function blog()

    {

        return $this->belongsTo(App\Blog::class);

    }

}

 

Khi Model Comment được cập nhật thì sẽ tự động cập nhật thuộc tính update_at của Blog

Tổng kết

Trên đây là 7 điều mà mình muốn chia sẻ với các bạn để tận dụng tối đa khi làm việc với Model

#Techtalk


> Chạm ngay để trải nghiệm Lộ trình Kiến tạo IT 4.0 được 35.000 học viên tin chọn: https://bit.ly/2L0TreC

HỆ THỐNG ĐÀO TẠO CNTT QUỐC TẾ BACHKHOA-APTECH

- 18 năm kiến tạo IT với 35.000 học viên thành đạt, lương 1000$
- Cam kết 100% học viên được giới thiệu việc làm tại 200 doanh nghiệp đối tác: CMC, Savis, Misa, Cốc Cốc, Sotatek...
- Cam kết mức lương sau tốt nghiệp từ 8 TRIỆU ĐỒNG TRỞ LÊN.
- Tiên phong 3T độc quyền: mô hình Làm trước học sau, hệ sinh thái giáo dục toàn diện, phương pháp kiến tạo IT đầu tiên tại Việt Nam.
- Thiết kế lộ trình sinh viên IT 4.0: 800 giờ chắc kiến thức, vững kỹ năng, làm chủ Tiếng Anh, bỏ túi 8 kỹ năng mềm, trải nghiệm 20 hoạt động ngoại khóa/1 năm để tự tin hội nhập.
> Hotline: 0968.27.6996

#BachkhoaAptech #Làmtrướchọcsau #KiếntạoIT

   0968276996
< wire:id="95oQL2dAQJkaIDn87AEL" wire:initial-data="{"fingerprint":{"id":"95oQL2dAQJkaIDn87AEL","name":"embedded.footer","locale":"vn"},"effects":{"listeners":[]},"serverMemo":{"children":[],"errors":[],"htmlHash":"26380eb1","data":[],"dataMeta":[],"checksum":"c7dafc6d4f5824672108a9a42e4c70f469e3563d141d3e2632feec8c823cc1f1"}}"!-- Messenger Plugin chat Code -->