首先,我们要清楚搜索框中根据关键字进行条件搜索发送的是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实现搜索功能代码详解