首先,我们要清楚搜索框中根据关键字进行条件搜索发送的是Get请求,并且是向当前页面发送Get请求

//示例代码 请求路径为当前页面路径 "/product"

当我们要实现多条件搜索功能时,可以将搜索条件封装为一个Map集合,再根据Map集合进行搜索

Controller层代码:

@GetMapping("/product")

public String list(@RequestParam(required = false,defaultValue = "1",name = "p")Integer pageNo,

@RequestParam(required = false,defaultValue = "")String productName,

@RequestParam(required = false,defaultValue = "")String place,

@RequestParam(required = false,defaultValue = "")Integer typeId,

@RequestParam(required = false,defaultValue = "")BigDecimal minPrice,

@RequestParam(required = false,defaultValue = "")BigDecimal maxPrice,

Model model) {

Map searchParam = new HashMap<>();

searchParam.put("productName",productName);

searchParam.put("place",place);

searchParam.put("typeId",typeId);

searchParam.put("minPrice",minPrice);

searchParam.put("maxPrice",maxPrice);

PageInfo pageInfo = kaolaService.findByPageNo(pageNo,searchParam);

model.addAttribute("pageInfo",pageInfo);

return "product/list";

}

业务层代码:

public PageInfo findByPageNo(Integer pageNo, Map searchParam) {

PageHelper.startPage(pageNo,10);

List kaolaList = kaolaMapper.findBySearchParamWithType(searchParam);

return new PageInfo<>(kaolaList);

}

MyBatis中的mapper.xml:

SELECT

kaola.*, kaola_type.id AS 'kaolaType.id',

kaola_type.type_name AS 'kaolaType.typeName',

parent_id AS 'kaolaType.parentId'

FROM

kaola

INNER JOIN kaola_type ON kaola.type_id = kaola_type.id

kaola.product_name LIKE concat('%',#{productName},'%')

and kaola.place = #{place}

and kaola.type_id = #{typeId}

= #{minPrice} ]]>

ORDER BY kaola.id DESC

这样,就可以从前端到后端实现多条件搜索功能了。我们还会遇到这样一种情况,在输入搜索条件时,显示列表会不断自动刷新,这里其实用到了Ajax的相关内容,在输入的过程中,会不断发出Ajax请求,然后刷新页面。

value="${param.productName}"是从请求url的参数中获取值,实现在输入关键字搜索后刷新页面显示关键字这一功能,直接上图:

在输入中文关键字进行搜索时,可以使用encodeURIComponent解决url路径显示中文乱码问题:

//分页

$('#pagination-demo').twbsPagination({

totalPages: ${pageInfo.pages},

visiblePages: 10,

first:'首页',

last:'末页',

prev:'上一页',

next:'下一页',

href:"?productName="+encodeURIComponent('${param.productName}')+"&place="+encodeURIComponent('${param.place}')

+ "&typeId=${param.typeId}&minPrice=${param.minPrice}&maxPrice=${param.maxPrice}&p={{number}}"

});

点击查看大图

搜索结果

总结

以上所述是小编给大家介绍的Java实现搜索功能代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

java 搜索_Java实现搜索功能代码详解相关推荐

  1. java搜索代码_Java实现搜索功能代码详解

    首先,我们要清楚搜索框中根据关键字进行条件搜索发送的是get请求,并且是向当前页面发送get请求 //示例代码 请求路径为当前页面路径 "/product" 当我们要实现多条件搜索 ...

  2. android收藏功能demo,Android使用Realm数据库实现App中的收藏功能(代码详解)

    前 言 App数据持久化功能是每个App必不可少的功能,而Android最常用的数据持久化方式主要有以下的五种方式: 使用SharedPreferences存储数据: 文件存储数据: SQLite数据 ...

  3. php怎么自定义设置打印区域,JavaScript_jQuery实现区域打印功能代码详解,使用CSS控制打印样式,需要设 - phpStudy...

    jQuery实现区域打印功能代码详解 使用CSS控制打印样式,需要设置样式media="print",并且将页面中不需要打印的元素的样式display属性设置为none.如DEMO ...

  4. java 深拷贝_java 深拷贝与浅拷贝机制详解

    java 深拷贝与浅拷贝机制详解 概要: 在Java中,拷贝分为深拷贝和浅拷贝两种.java在公共超类Object中实现了一种叫做clone的方法,这种方法clone出来的新对象为浅拷贝,而通过自己定 ...

  5. java 复合_Java复合语句的使用方法详解

    与 C 语言及其他语言相同, Java 语言的复合语句是以整个块区为单位的语句,所以又称为块语句.下面我们来看看有关复合语句的使用方法和实例. 复合语句由开括号"{"开始,闭括号& ...

  6. java 可见性_Java并发编程-volatile可见性详解

    前言 要学习好Java的多线程,就一定得对volatile关键字的作用机制了熟于胸.最近博主看了大量关于volatile的相关博客,对其有了一点初步的理解和认识,下面通过自己的话叙述整理一遍. 有什么 ...

  7. java中流_Java中流的有关知识点详解

    Java中流的有关知识点详解 发布时间:2020-09-17 03:50:59 来源:脚本之家 阅读:103 作者:mumu1998 什么是流? 流:程序和设备之间连接起来的一根用于数据传输的管道,流 ...

  8. switch java 语法_Java编程—switch语句语法详解

    5.3.2 switch语句 switch关键字的中文意思是开关.转换的意思,switch语句在条件语句中特别适合做一组变量相等的判断,在结构上比if语句要清晰很多. switch语句的语法格式为: ...

  9. java装饰模式_Java装饰者模式实例详解

    本文实例讲述了Java装饰者模式.分享给大家供大家参考,具体如下: 装饰模式 在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能.它是通过创建一个包装对象,也就是装饰来包裹真实的对象. 装 ...

最新文章

  1. 【数据库】SQLite和MySQL之间的对比和选择
  2. 【Windows编程】系列第三篇:文本字符输出
  3. 第20讲:代理的基本原理和用法
  4. MicroPython 1.8.6重新支持512K的模块
  5. rsync的基本操作
  6. [原创]同一个Tomcat,配置多个context、多个Host
  7. CUDA C编程权威指南 第一章
  8. C++ 过去的这一年
  9. Menu控件在IE8中子菜单不能正常显示的解决方案(转)
  10. JS 输入框智能提示
  11. MQTT 以太网IO信号采集模块
  12. 中基鸿业人人都要懂的投资理财常识
  13. 浏览器工作原理和实践
  14. 《沃顿商学院谈判课》读书笔记
  15. 算法竞赛入门经典(紫书)第四章——Spreadsheet Tracking UVA-512
  16. 谈马云创业人生中的十大苦难
  17. 【深度学习】数据读取与数据扩增方法
  18. 软件实训之深刻理解原型图设计的核心
  19. 商场三十六计——第32计 “空城计”
  20. 数字电子技术(四)组合逻辑电路

热门文章

  1. 磁盘有空间但是显示内存不足
  2. 移动端判断手指上滑下滑
  3. 如何处理​PHP 表单?
  4. 投资理财 - 电影大空头观后感
  5. 机器学习之径向基神经网络
  6. linux3.0 usb键盘驱动,USB3.0驱动下载
  7. Ansoftnbsp;andnbsp;Ansys
  8. 初一下册计算机教案,七年级下册信息技术教案
  9. Ubuntu20.04安装步骤详细指导
  10. 2020年第三届中科实数杯 Android模拟器分析部分 wp