Solr的页面展示以及高亮显示
时间:2019-11-22
本文章向大家介绍Solr的页面展示以及高亮显示,主要包括Solr的页面展示以及高亮显示使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Solr主要是为了做搜索引擎,前台传来的数据,我们通过在solr中设置对应的域,来对solr库中的对应的字段进行中文分词检索,来返回map,前台获取。
代码展示:
前台传来一个map集合,带着所有关键字到后台获取列表集合
//高亮查询 @Override public Map<String, Object> searchList(Map<String, Object> map) { //不写泛型返回的话,会出现IO异常 Map<String,Object> map1 = new HashMap(); //获取前端传递的当前页码和展示数量 Integer pageNo = (Integer)map.get("pageNo"); Integer pageSize = (Integer)map.get("pageSize"); if (pageNo==null || pageNo<=0){ pageNo=1; } pageNo = (pageNo-1)*pageSize; //高亮查询 HighlightQuery query = new SimpleHighlightQuery(); //起始索引,是当前页码-1*当前展示数量 query.setOffset(pageNo); query.setRows(pageSize); //高亮属性的设置 HighlightOptions options = new HighlightOptions(); //设定属性名,属性名必须与solr字段名一致, options.addField("item_title"); //高亮属性的设置前缀 options.setSimplePrefix("<em style='color:red'>"); //高亮属性的设置后缀 options.setSimplePostfix("</em>"); //设置高亮选项 query.setHighlightOptions(options); //查询条件的设置 Criteria criteria = new Criteria("item_keywords").is(map.get("keywords")); //添加复杂查询 query.addCriteria(criteria); HighlightPage<Item> page = solrTemplate.queryForHighlightPage(query, Item.class); //5、遍历实体集合,将符合要求的当西设置高亮 //华为 mate <em style='color:green'>华为mate</em> for (HighlightEntry<Item> h : page.getHighlighted()) {//循环高亮入口 Item item = h.getEntity();//获取原实体 //h.getHighlights()高亮的内容, if (h.getHighlights().size() >0 && h.getHighlights().get(0).getSnipplets().size()>0){ //因为上面的复杂查询不能够直接去查询,我们要将符合要求的结果拿出来,在设置格式,再赋值给对象 item.setTitle(h.getHighlights().get(0).getSnipplets().get(0)); } } List<Item> content = page.getContent(); //将list集合,以及前台所需要的总共页数量,总记录数,以及得到的集合返回到前端 map1.put("rows",content); map1.put("total",page.getTotalElements()); map1.put("totalPages",page.getTotalPages()); return map1; }
原文地址:https://www.cnblogs.com/guanyuehao0107/p/11912047.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 使用kind搭建kubernetes
- 如何设计一个牛逼的API接口
- 猿实战17——实现你未必知晓的运费模板
- 这 5 个 VSCode 扩展提高你的开发效率
- 猿实战18——商品发布之类目选择
- 树莓派基础实验1:双色LED灯实验
- 【机器学习基础】机器学习中类别变量的编码方法总结
- 树莓派基础实验2:RGB-LED实验
- 【Python基础】Python画王者荣耀英雄能力雷达图
- 树莓派基础实验4:继电器实验
- 树莓派基础实验5:激光传感器实验
- 树莓派基础实验6:轻触开关按键实验
- 从 lsof 开始,深入理解 Linux 虚拟文件系统!
- 原来 8 张图,就可以搞懂「零拷贝」了
- 构造函数没有返回值是怎么赋值的?