博客
关于我
实体类转化为VO返回给前端的方法
阅读量:371 次
发布时间:2019-03-04

本文共 2117 字,大约阅读时间需要 7 分钟。

返回给前端的时候,我以前一直都是直接用实体类entity直接返回的。但是到后面我越来越发现这样子很不方便:

  1. 比如这个实体类中有许多属性我不想返回给前端,那我只好写个null;
  2. 我要一次查询多张表,返回许多数据的话,就肯定只能多去封装一个大类,也就是VO类

其实这里的方法有几种,最普通的及时一个个set了:

以遍历集合为例:

①遍历出来后取出每个元素,一个个set后再添加到新的集合里

//普通类型        List
phoneCategoryList = phoneCategoryRepository.findAll(); //常规写法 List
phoneCategoryVOList = new ArrayList<>(); for (PhoneCategory phoneCategory : phoneCategoryList) { PhoneCategoryVO phoneCategoryVO = new PhoneCategoryVO(); phoneCategoryVO.setCategoryName(phoneCategory.getCategoryName()); phoneCategoryVO.setCategoryType(phoneCategory.getCategoryType()); phoneCategoryVOList.add(phoneCategoryVO); }

②用Java8的lambda表达式:

List
phoneCategoryVOList = phoneCategoryList.stream() .map(e -> new PhoneCategoryVO( e.getCategoryName(), e.getCategoryType() )).collect(Collectors.toList());

③使用commons-lang3或者直接org.springframework.beans. BeanUtils的copyProperties方法:

List
phoneInfoVOList = new ArrayList<>(); for (PhoneInfo phoneInfo : phoneInfoList) { PhoneInfoVO phoneInfoVO = new PhoneInfoVO(); //将phoneSpecs中与phoneSpecsVO属性相同的进行拷贝给VO BeanUtils.copyProperties(phoneInfo,phoneInfoVO); //如果还有不同进行手动赋值 phoneInfoVO.setTag(PhoneUtil.createTag(phoneInfo.getPhoneTag())); phoneInfoVOList.add(phoneInfoVO); }

注意如果实体类中有不想赋值的属性,可以使用copyProperties(Object source, Object target, String... ignoreProperties),后面加上忽略的名字;

上面的方法对应的lambda式为:

List
phoneInfoVOList = phoneInfoList.stream() .map(e -> new PhoneInfoVO( e.getPhoneId(), e.getPhoneName(), e.getPhonePrice()+".00", e.getPhoneDescription(), PhoneUtil.createTag(e.getPhoneTag()), e.getPhoneIcon() )).collect(Collectors.toList());

可以看出在这种情况下,lambda表达式要手动的赋值,而使用BeanUtils的copyProperties方法就可以简洁。不过如果说返回给前端的VO和实体类的属性并不一样的话,使用lambda表达式就更加方便了。

当然,我对于lambda表达式还不够熟练,这个就只能多练习了!

转载地址:http://bxyg.baihongyu.com/

你可能感兴趣的文章
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>
MuseTalk如何生成高质量视频(使用技巧)
查看>>