根据 Grails 最佳实践和 MVC 模式,我正在尝试确定何时是引入服务而不是不断增加控制器的正确时间。我发现这有点矛盾,我读到的关于最佳实践的内容和似乎是常见的做法,所以很想听听其他人对此的看法。
考虑到 GORM 调用,我原以为与 GORM 相关的任何事情都应该真正进入服务。虽然我自己没有实践过这个,尤其是在编写非常基本的控制器方法时show
,比如简单地get()
在域类上执行 a ,然后渲染一个视图以显示检索到的对象的详细信息。
但是,在学习了诸如“清洁代码”之类的书籍和类似书籍之后,维护良好的代码应该具有凝聚力,并且方法应该理想地只执行单个任务。那么在完美的世界中,控制器中的 show 方法是否只负责在渲染视图之前确定要显示的对象?从数据库中检索可以进入数据库中的一个方法,该方法的唯一任务是从数据库中检索并在未找到时抛出异常等。
但是,是的,这似乎有点矫枉过正。
所以更进一步,create()
orupdate()
方法。同样,目前 Grails 生成的代码将所有内容都放入控制器中,根本不使用任何服务。
那么什么时候建议我们需要使用服务呢?是不是只有在事务必须发生时,例如,在create()
通话中,我们可能还希望将记录写入日志文件以保留各种审计日志。这肯定需要服务吗?
我很想听听其他人认为引入服务的正确时间,我想这因人而异。