博客
关于我
实体类转化为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主从复制,读写分离,半同步复制实现
查看>>
MySQL主从失败 错误Got fatal error 1236解决方法
查看>>
MySQL主从架构与读写分离实战
查看>>
MySQL主从篇:死磕主从复制中数据同步原理与优化
查看>>
mysql主从配置
查看>>
MySQL之2003-Can‘t connect to MySQL server on ‘localhost‘(10038)的解决办法
查看>>
MySQL之CRUD
查看>>
MySQL之DML
查看>>
Mysql之IN 和 Exists 用法
查看>>
MYSQL之REPLACE INTO和INSERT … ON DUPLICATE KEY UPDATE用法
查看>>
MySQL之SQL语句优化步骤
查看>>
MYSQL之union和order by分析([Err] 1221 - Incorrect usage of UNION and ORDER BY)
查看>>
Mysql之主从复制
查看>>