分享 PHP trait 在 Laravel 中的使用个人心得

trait 是在PHP5.4中为了方便代码复用的一种实现方式,但目前我在看的的PHP项目中较少看的有程序员去主动使用这个实现方式,在laravel中有很多 trait 的使用,关于trait 在 laravel 的使用请参看 Laravel 在哪些地方用了 trait?

我曾在 Laravel 中大型项目面向对象架构 引用分享过一个他人的架构设计实践,在他的实践中大量使用了依赖注入。这是一种可行的方式,而同样的使用 trait 可以实现同样的功能,而且应用场景更多。

model 中使用

model是随着项目的推移会慢慢的变得肥大难以维护,因为传统的方式是将数据库访问逻辑都写在这里面,而 laravel 的模型里除了数据访问的逻辑还会有数据表之间的关联关系,访问器,修改器,监视的字段,白名单,黑名单等等。

而当一个模型在有了这么多东西后模型就会出现维护困难问题,当然数据访问可以通过 资源库模式(Repository)进行分离,但当项目已经有很多数据访问写在模型里使用资源库模式就是一个费力费时的改造工程。

而使用 trait 既可以实现代码分离又可以不用在逻辑层做任何处理。

我们只需要创建一个trait,将数据访问的所有方法全部移动到这个trait中,然后在原来的模型中 use 这个trait就可以了,这样就方便的实现了代码的分离。

同样的你可以将访问器,修改器分离,甚至是常常使用的模型定义,比如laravel的软删除就是用这种方式实现的,你可以自己定义一些常用的模型功能代码,比如内容的审核功能。

我的建议是将model放在models文件夹中,其他trait放在models中建立的文件夹中,这样就近的方便查找修改,比如我就将访问器修改器放在app/Models/Attribuite文件夹中,然后使用模型名类型名的驼峰命名文件。
比如 User 模型的访问器修改器我的文件路径就是app/Models/Attribuite/UserAttribute.php。

当然你可以分的更加细致,把访问器单独定义一个trait,修改器单独定义一个。

app/Models/Attribuite/UserGetAttribute.php
app/Models/Attribuite/UserSetAttribute.php

Controller 中的使用

在laravel中有一个基类控制器里面已经有几个trait的使用了,比如认证,验证器,我们在使用基类控制器时候如果有较少的基类方法可以直接写在这个基类控制器里,当有很多的时候维护和查找他们也是一个麻烦事,这时候就可以用trait将他们分类出来。

而一些要复用的代码可能只在几个控制器里需要用到,这时候可以仅仅在这几个控制器里使用定义好的trait。

还有一种使用方式是控制器分离,当控制器中有越来越多方法时候,分离控制器中的方法也是必要的,一般的做法是新建一个控制器,然后将一些原来控制器中的方法移动过去,然后再去修改路由配置。用trait可以实现分离而不需要修改路由配置,新建一个trait将需要分离的方法移动过去,然后在原控制器中使用这个 trait 。

本帖已被设为精华帖!
本帖由 Summer 于 2年前 加精
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 6
zoroo

感谢分享:thumbsup:

2年前 评论
Mantis

我们公司都是新建一个Modules模块,在里面写数据库访问逻辑,很少有用到Trait的,请问这两者有区别吗??

2年前 评论

@chunlintang trait可以代码复用,比如laravel的软删除,很多模型里都要用到,用trait可以快速给模型加上这个功能,比如你自己写一个内容审核,也可以用trait快速给模型加上这个功能,等等一些通用的功能

2年前 评论

感谢分享,如果能提供代码示例就更好了~

2年前 评论

谢谢分享,不过确实是有点太干了,干货这么分享会让人不易理解。

2年前 评论
lucifergit

没有demo说了我也不知道怎么用

2年前 评论

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!