8

根据 Grails 最佳实践和 MVC 模式,我正在尝试确定何时是引入服务而不是不断增加控制器的正确时间。我发现这有点矛盾,我读到的关于最佳实践的内容和似乎是常见的做法,所以很想听听其他人对此的看法。

考虑到 GORM 调用,我原以为与 GORM 相关的任何事情都应该真正进入服务。虽然我自己没有实践过这个,尤其是在编写非常基本的控制器方法时show,比如简单地get()在域类上执行 a ,然后渲染一个视图以显示检索到的对象的详细信息。

但是,在学习了诸如“清洁代码”之类的书籍和类似书籍之后,维护良好的代码应该具有凝聚力,并且方法应该理想地只执行单个任务。那么在完美的世界中,控制器中的 show 方法是否只负责在渲染视图之前确定要显示的对象?从数据库中检索可以进入数据库中的一个方法,该方法的唯一任务是从数据库中检索并在未找到时抛出异常等。

但是,是的,这似乎有点矫枉过正。

所以更进一步,create()orupdate()方法。同样,目前 Grails 生成的代码将所有内容都放入控制器中,根本不使用任何服务。

那么什么时候建议我们需要使用服务呢?是不是只有在事务必须发生时,例如,在create()通话中,我们可能还希望将记录写入日志文件以保留各种审计日志。这肯定需要服务吗?

我很想听听其他人认为引入服务的正确时间,我想这因人而异。

4

2 回答 2

6

我推荐你这篇文章: http: //www.infoq.com/articles/grails-best-practices

于 2012-08-24T13:41:04.170 回答
3

我们在 Domain 类中创建静态方法来封装查询。服务仅用于事务操作或具有多个域交互的非常复杂的查询。控制器只是调用域或服务方法。

于 2012-08-24T14:38:16.937 回答