请问在传统的开发模式MVC下,增加Entity实体类有哪些好处和优点?

越来越多的公司在开发模式下做出了改进,传统的MVC老生常谈,那么增加了一层Entity有什么好处和优点,Entity主要做哪一些处理?请了解的大佬回答哦,感谢

阅读 3.6k
4 个回答

MVC模式有个弊端,业务逻辑不好放。
放在Model中的话,跨Model的业务逻辑怎么办?
放在Controller的话,业务逻辑复用怎么办?
从我的实践来说,Model就是用来放Entity的,也就是数据结构,不带有业务逻辑。所以放着Model不用去加一层Entity我实在想不出什么优点。
如果需要写业务逻辑,需要新增一个service层。

这个你可以参考 laravel框架的一些写法,它有一个 Repositories文件夹,可以将许多具体的业务逻辑写在这个里边,然后在 Controller 里边调用,大概是这样的:Model->Repositories->Controller。

概念:

VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。

DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对象。

DO(Domain Object):领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。

PO(Persistent Object):持久化对象,它跟持久层(通常是关系型数据库)的数据结构形成一一对应的映射关系,如果持久层是关系型数据库,那么,数据表中的每个字段(或若干个)就对应PO的一个(或若干个)属性。

以下列举几个模型在应用中的作用:

  • 用户发出请求(可能是填写表单),表单的数据在展示层被匹配为VO。
  • 展示层把VO转换为服务层对应方法所要求的DTO,传送给服务层。
  • 服务层首先根据DTO的数据构造(或重建)一个DO,调用DO的业务方法完成具体业务。
  • 服务层把DO转换为持久层对应的PO(可以使用ORM工具,也可以不用),调用持久层的持久化方法,把PO传递给它,完成持久化操作。
  • 对于一个逆向操作,如读取数据,也是用类似的方式转换和传递,略。

今天突然想到这样一个比喻,
Controller相当于nginx,只是转发请求,接收参数并过滤参数;
Entity相当于php-fpm,是真正的逻辑处理,在Entity中还可以调用Model,将处理的结果返回给Controller,Contoller进行页面渲染,填充数据,响应请求.

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏