基于 React + Redux/Mobx 搞定复杂项目状态管理|一起学习

download:基于 React + Redux/Mobx 搞定复杂项目状态管理

PO(Persistant Object - 持久化对象)

该概念随着ORM产生,可以看成是与数据库中的表相映射的Java对象。通常就是对应数据库中某个表中的一条记录。PO仅仅用于表示数据,没有任何数据操作。通常遵守Java Bean的规范,拥有 getter/setter方法。
PO的生命周期:是向数据库中添加新数据时创建,删除数据库中数据时削除的。并且它只能存活在一个数据库连接中,断开连接即被销毁。
PO的作用:可以把数据表中一条记录作为一个对象处理,可以方便的转为其它对象。PO是有状态的,每个属性代表其当前的状态。使用它,可以使我们的程序与物理数据解耦,并且可以简化对象数据与物理数据之间的转换。
PO的特点:

PO的属性是跟数据库表的字段一一对应的
PO对象需要实现序列化接口
一个POJO持久化后就是PO

BO(Business Object - 业务对象)

BO用于表示一个业务对象,它包括了业务逻辑,常常封装了对DAO和RPC等的调用,可以进行PO与VO/DTO之间的转换。
BO通常位于业务层,要区别于直接对外提供服务的服务层:BO提供了基本业务单元的基本业务操作,在设计上属于被服务层业务流程调用的对象,一个业务流程可能需要调用多个BO来完成。

DO(Domain Object - 领域对象)

领域对象就是从现实世界中抽象出来的有形或无形的业务实体。通常位于业务层中。

VO(Value Object/View Object - 值对象/视图对象)

Value Object,值对象,也称为业务对象,是存活在业务层的,是业务逻辑使用的,它存活的目的就是为数据提供一个生存的地方(实际上跟DO有点类似)。
VO的属性是根据当前业务的不同而不同的,也就是说,它的每一个属性都一一对应当前业务逻辑所需要的数据的名称。
VO通常用于业务层之间的数据传递,其仅仅包含数据。但应是抽象出的业务对象。根据业务的需要,其可以和表对应或者不。用new关键字创建,由GC进行回收。

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

DTO(Data Transfer Object - 数据传输对象)

DTO概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载。
DTO用于表示一个数据传输对象,通常用于不同服务或服务不同分层之间的数据传输。
DTO与VO与类似,但也有一些不同,这个不同主要是设计理念上的,比如API服务需要使用的是DTO,而用于展示层页面的使用的是VO。例如,为了展示方便,在VO的性别字段存的是男和女,而在DTO中存的是1或者2这样的代码。

你可能感兴趣的:(基于 React + Redux/Mobx 搞定复杂项目状态管理|一起学习)