如果你已经使用 Laravel 开发了一段时间,你可能听说过“干净的代码”这个词。但它在 Laravel 开发的背景下实际上意味着什么?更重要的是,你为什么要关心?
“干净的代码”是指易于理解、维护和扩展的代码。干净的代码架构通过提供一种结构使这一点更进一步,使您可以随着应用程序的增长更轻松地保持代码库干净。在这篇博客中,我们将探索如何在 Laravel 中实现干净的代码架构,使您的项目更具可扩展性、可维护性和工作乐趣。
干净的代码架构是一种组织应用程序的方式,使其更易于维护和扩展。它不依赖于任何特定的框架或语言,并将您的应用程序分为多个层。每一层都有特定的职责,并且与其他层松散耦合。
这种分离可以帮助您避免臭名昭著的“意大利面条代码”,即所有内容都纠缠在一起。凭借干净的代码架构,您的业务逻辑与用户界面和数据访问保持分离,允许您对应用程序的一部分进行更改,而不会破坏整个系统。
编写干净的代码不仅仅是让你的代码看起来漂亮;而是让你的代码看起来更漂亮。从长远来看,这是为了让您的生活更轻松。当你的代码干净时:
在像 Laravel 这样鼓励快速开发的框架中,人们很容易倾向于专注于快速构建而不是干净构建。但通过遵循干净的代码原则,从长远来看,您最终会节省时间和精力。
在我们深入探讨如何在 Laravel 中实现干净的代码架构之前,让我们先回顾一下几个关键原则:
现在,让我们看看如何在 Laravel 应用程序中实现干净的代码架构。
干净代码架构的核心是实体和用例。实体是系统中的核心对象(例如帖子或用户),用例定义了您可以使用这些实体执行的操作(例如创建帖子或删除用户)。
在 Laravel 中,实体可以表示为 Eloquent 模型,而用例通常是在这些模型上执行特定操作的服务。
例如,让我们创建一个简单的用例来创建博客文章:
// app/Domain/Post/Post.php class Post { private $title; private $content; public function __construct($title, $content) { $this->title = $title; $this->content = $content; } // Getter methods and other domain logic }
这是创建新帖子的用例:
// app/Services/Post/CreatePostService.php class CreatePostService { private $postRepository; public function __construct(PostRepositoryInterface $postRepository) { $this->postRepository = $postRepository; } public function execute($data) { $post = new Post($data['title'], $data['content']); $this->postRepository->save($post); } }
在干净的代码架构中,存储库处理数据访问,接口定义存储库应实现的方法。这样,您的业务逻辑不依赖于您正在使用的数据库或 ORM,而是依赖于抽象。
让我们为 PostRepository 创建一个接口:
// app/Repositories/PostRepositoryInterface.php interface PostRepositoryInterface { public function save(Post $post): void; public function findById($id): ?Post; }
以及此存储库的 Eloquent 实现:
// app/Repositories/EloquentPostRepository.php class EloquentPostRepository implements PostRepositoryInterface { public function save(Post $post): void { // Save post using Eloquent } public function findById($id): ?Post { // Fetch post using Eloquent } }
您的控制器应该很薄,这意味着它们应该只处理HTTP请求并将繁重的工作委托给服务。通过使用依赖注入,您可以将必要的服务注入到您的控制器中。
// app/Http/Controllers/PostController.php class PostController { private $createPostService; public function __construct(CreatePostService $createPostService) { $this->createPostService = $createPostService; } public function store(Request $request) { $this->createPostService->execute($request->all()); return response()->json(['message' => 'Post created!']); } }
所有业务逻辑都应该存在于服务中。这可以使您的控制器保持干净,并确保您的逻辑可以在应用程序的不同部分中重用。
// app/Services/Post/CreatePostService.php class CreatePostService { private $postRepository; public function __construct(PostRepositoryInterface $postRepository) { $this->postRepository = $postRepository; } public function execute($data) { $post = new Post($data['title'], $data['content']); $this->postRepository->save($post); } }
让我们看一下构建简单博客平台的真实示例。以下是如何使用干净的代码架构构建它:
这种分离可确保您的代码保持模块化且易于测试。例如,如果您决定从 Eloquent 切换到另一个 ORM,您只需要更新存储库实现,而不是整个应用程序。
干净的代码架构不仅仅适用于大型企业应用程序 - 它是一种心态,可以帮助您保持代码库干净和有组织,即使对于中小型项目也是如此。通过分离关注点、使用依赖注入并遵循单一职责原则,您会发现您的 Laravel 应用程序更易于维护、测试和扩展。
从小事做起。尝试重构 Laravel 应用程序的一部分以遵循简洁的代码架构,您很快就会看到好处。
编码愉快!
以上是Laravel 中的整洁代码架构:实用指南的详细内容。更多信息请关注PHP中文网其他相关文章!