SpringBoot+Mybatis plus+React实现条件选择切换搜索实践

网友投稿 283 2022-09-24


SpringBoot+Mybatis plus+React实现条件选择切换搜索实践

在写React前端逻辑时,经常遇到可以切换不同条件的列表查询功能,例如下边截图这样的,其实,这块代码基本都一个逻辑,可以一次性将实现过程记录下来,待以后再遇到时,直接根据笔记复用即可。

一、首先,是前端React页面代码,这类搜索框,一般都是放在Form表单当中,然后使用有前缀下拉框选项的Input组件,这类模式的组件是在Input组件当中实现一个addonBefore属性即可,如下代码:

render () {

let { getFieldDecorator } = this.props.form;

return (

{getFieldDecorator('searchUser', {

initialValue: ""

})(

addonBefore={

getFieldDecorator('condition', {

initialValue: 'name'

})(

)

}

/>

)}

);

}

二、写好表单页面后,就可以对该表单逻辑进行开发。因为该搜索框对应多种方式,但输入框只有一个,也就是多对一的情况,故而需要做一些转换,需要将输入框的值,相应转换为对应下拉框选项的值,因此,可以用switch判断来做转换,当然,你也可以用if-elhttp://se,我试过if-else的效果,看起来就是一坨......

稍微解释一下这段代码,假如下拉框是以“学生姓名”为维度来搜索,那么表单的getFieldDecorator('condition')属性值即“name”,也就是values.condition==“name”,就会跳转至values.name = values.searchValue,就意味着是搜索条件name的值,为对应输入框的值values.searchValue。在表单当中,输入框的属性label是getFieldDecorator('searchUser')。

submit = (e) => {

e.preventDefault()

let { form, getSthttp://udentList } = this.props

let values = {}

form.validateFieldsAndScroll({ first: true },

((errors, value) => {

if (errors) {

message.error(getFormFirstErrorMsg(errors));

} else {

values = trimObjectValues(value);

switch (values.condition) {

case "name":

values.name = values.searchValue;

break;

case "className":

values.className = values.searchValue

break;

case "studentNo":

values.studentNo = values.searchValue

break;

default:

break;

}

getStudentList(params);

}

}))

}

3、最后,就是后端逻辑实现

@Data

public class Student {

private String name;

private String className;

private String sex;

}

public interface StudentMapper extends BaseMapper {}

这里使用了Mybatis plus的ORM框架,可以直接使用lambda表达式的搜索条件进行,因为搜索条件搜索,故而,需要用like的模糊搜索,搜索条件是name+"%",没有两边都用"%",是因为若第一个模糊条件有索引的话,那么"%"+name+"%"将会造成索引失效。

public List getStudents(Student rIYjMJDQJeqVO) {

String name = reqVO.getName();

String className = reqVO.getClassName();

String sex IYjMJDQJ= reqVO.getSex();

List students = studentMapper.selectList(

new QueryWrapper().lambda()

.like(StringUtils.isNotEmpty(name),Student::getName,name+"%")

.like(StringUtils.isNotEmpty(className),Student::getClassName,className+"%")

.like(StringUtils.isNotEmpty(sex),Student::getSex,sex+"%")

);

return students;

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:不同域间的主机通过OSPF实现互联互通(基于ospf协议的局域网设计与实现)
下一篇:ACL访问控制列表配置实例 (一)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~