当前位置: 首页 > wzjs >正文

网站建设技术团队中国新闻社

网站建设技术团队,中国新闻社,网站地图的制作,网站高端网站建设表达式解析-BeanPath 由来 很多JavaBean嵌套着很多层对象,这其中还夹杂着Map、Collection等对象,因此获取太深的嵌套对象会让代码变得冗长不堪。因此我们可以考虑使用一种表达式来获取指定深度的对象,于是BeanResolver应运而生。 原理 通过传…

表达式解析-BeanPath

由来


很多JavaBean嵌套着很多层对象,这其中还夹杂着Map、Collection等对象,因此获取太深的嵌套对象会让代码变得冗长不堪。因此我们可以考虑使用一种表达式来获取指定深度的对象,于是BeanResolver应运而生。

原理

通过传入一个表达式,按照表达式的规则获取bean中指定的字段值。

表达式分为两种:

  • .表达式,可以获取Bean对象中的属性(字段)值或者Map中key对应的值
  • []表达式,可以获取集合等对象中对应index的值

栗子:

  • person 获取Bean对象下person字段的值,或者Bean本身如果是Person对象,返回本身。
  • person.name 获取Bean中person字段下name字段的值,或者Bean本身如果是Person对象,返回其name字段的值。
  • persons[3] 获取persons字段下第三个元素的值(假设person是数组或Collection对象)
  • person.friends[5].name 获取person字段下friends列表(或数组)的第5个元素对象的name属性

使用

由于嵌套Bean定义过于复杂,在此我们省略,有兴趣的可以看下这里:cn.hutool.core.lang.test.bean(src/test/java下)下定义了测试用例用的bean。
首先我们创建这个复杂的Bean(实际当中这个复杂的Bean可能是从数据库中获取,或者从JSON转入)
这个复杂Bean的关系是这样的:
定义一个Map包含用户信息(UserInfoDict)和一个标志位(flag),用户信息包括一些基本信息和一个考试信息列表(ExamInfoDict)。

//------------------------------------------------- 考试信息列表
ExamInfoDict examInfoDict = new ExamInfoDict();
examInfoDict.setId(1);
examInfoDict.setExamType(0);
examInfoDict.setAnswerIs(1);ExamInfoDict examInfoDict1 = new ExamInfoDict();
examInfoDict1.setId(2);
examInfoDict1.setExamType(0);
examInfoDict1.setAnswerIs(0);ExamInfoDict examInfoDict2 = new ExamInfoDict();
examInfoDict2.setId(3);
examInfoDict2.setExamType(1);
examInfoDict2.setAnswerIs(0);List<ExamInfoDict> examInfoDicts = new ArrayList<ExamInfoDict>();
examInfoDicts.add(examInfoDict);
examInfoDicts.add(examInfoDict1);
examInfoDicts.add(examInfoDict2);//------------------------------------------------- 用户信息
UserInfoDict userInfoDict = new UserInfoDict();
userInfoDict.setId(1);
userInfoDict.setPhotoPath("yx.mm.com");
userInfoDict.setRealName("张三");
userInfoDict.setExamInfoDict(examInfoDicts);Map<String, Object> tempMap = new HashMap<String, Object>();
tempMap.put("userInfo", userInfoDict);
tempMap.put("flag", 1);
下面,我们使用BeanPath获取这个Map下此用户第一门考试的ID:BeanPath resolver = new BeanPath("userInfo.examInfoDict[0].id");
Object result = resolver.get(tempMap);//ID为1
只需两句(甚至一句)即可完成复杂Bean中各层次对象的获取。

说明: 为了简化BeanPath的使用,Hutool在BeanUtil中也加入了快捷入口方法:BeanUtil.getProperty,这个方法的命名更容易理解(毕竟BeanPath不但可以解析Bean,而且可以解析Map和集合)。

例子

上面的文章是从糊涂官网上直接截取的。缺少了设置值的过程https://doc.hutool.cn/pages/BeanPath/#%E5%8E%9F%E7%90%86
下面我自己尝试的一些使用示例,供大家参考

  		Map<String, Object> map = new HashMap<>();map.put("name", "张三");map.put("age", 18);Map<String, Object> score = new HashMap<>();score.put("math", 100);score.put("english", 99);List<String> likeFood = new ArrayList<>();likeFood.add("apple");likeFood.add("banana");map.put("score", score);map.put("likeFood", likeFood);BeanPath matchScorePath = BeanPath.create("score.math");BeanPath likeFoodPath = BeanPath.create("likeFood[1]");// 输出结果System.out.println("matchScore"+matchScorePath.get(map));System.out.println("likeFood"+likeFoodPath.get(map));// 设置值matchScorePath.set(map, 90);likeFoodPath.set(map, "orange");System.out.println(((Map<String,Object>)map.get("score")).get("math"));System.out.println(((List)map.get("likeFood")).get(1));// 设置不存在的值BeanPath likeFoodPath1 = BeanPath.create("likeFood[2]");likeFoodPath1.set(map, "pear");System.out.println(((List)map.get("likeFood")).get(2));
http://www.dtcms.com/wzjs/412024.html

相关文章:

  • 网站轮播图片怎么做的淘宝运营培训
  • dw做的手机端网站搜索seo优化
  • 支付宝 手机网站支付接口2.0房地产最新消息
  • seo网站优化推广怎么做何鹏seo
  • 提供网站建设课程无锡百度公司王东
  • 做网站的意义百度首页排名优化多少钱
  • 网站被镜像怎么做网站关键词优化的价格
  • 四川建设培训网刷seo快速排名
  • 网站建设重要软文推广代理
  • 网站的差异平台宣传推广方案
  • 网站建设win2012企业管理系统
  • 建设信用卡激活中心网站百度数据平台
  • 哪个网站查备案价百度推广登录入口登录
  • 汕头网页网站制作百度电话怎么转人工客服
  • 太原网站建设baidu北京广告公司
  • 做动态网站的用工具栏百度推广app下载安卓版
  • 培训教育行业网站建设方案武汉百度关键词推广
  • 网站设计的工作内容网站关键词优化案例
  • 焦作网站制作-焦作网站建设-焦作网络公司-维科网络seo排名软件怎么做
  • 浦口区建设局网站爱站网长尾关键词挖掘
  • 淄博网站建设推广百度快速排名优化服务
  • 便宜点的WordPress太原seo外包平台
  • 建设银行企业网站无法打印回单销售平台软件有哪些
  • 大连建设教育网站seo排名推广
  • 网站建设 话术网络软文范文
  • 给女朋友做的网站源码建网站公司哪里好
  • 新云网站模版网站怎么建立
  • 什么网站专门学做湖北菜整合营销传播方案案例
  • 四川省建设厅申报网站公司快速建站
  • 南宁专业网站建设公司网页设计与制作软件有哪些