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

基于SpringBoot+Mybatis plus+React.js实现条件选择切换搜索功能

笔记/朱季谦

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

image

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

  render () {let { getFieldDecorator } = this.props.form;return (<Form onSubmit={this.submit} layout={'inline'}><FormItem>{getFieldDecorator('searchUser', {initialValue: ""})(<Input allowClear placeholder="请输入搜索条件"addonBefore={getFieldDecorator('condition', {initialValue: 'name'})(<Select style={{ width: 100 }}><Option value="name">学生姓名</Option><Option value="class">班级</Option><Option value="studentNo">学号</Option></Select>)}/>)}</FormItem></Form>);}

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

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

  submit = (e) => {e.preventDefault()let { form,  getStudentList } = this.propslet 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.searchValuebreak;case "studentNo":values.studentNo = values.searchValuebreak;default:break;}getStudentList(params);}}))}

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

@Data
public class Student {private String name;private String className;private String sex;
}
public interface StudentMapper extends BaseMapper<Student> {}

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

public List<Student> getStudents(Student reqVO) {String name = reqVO.getName();String className = reqVO.getClassName();String sex = reqVO.getSex();List<Student>  students = studentMapper.selectList(new QueryWrapper<Student>().lambda().like(StringUtils.isNotEmpty(name),Student::getName,name+"%").like(StringUtils.isNotEmpty(className),Student::getClassName,className+"%").like(StringUtils.isNotEmpty(sex),Student::getSex,sex+"%"));return students;}

相关文章:

基于SpringBoot+Mybatis plus+React.js实现条件选择切换搜索功能

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

【STM32】W25Q64 SPI(串行外设接口)

一、SPI通信 0.IIC与SPI的优缺点 https://blog.csdn.net/weixin_44575952/article/details/124182011 1.SPI介绍 同步&#xff08;有时钟线&#xff09;&#xff0c;高速&#xff0c;全双工&#xff08;数据发送和数据接收各占一条线&#xff09; 1&#xff09;SCK:时钟线--&…...

如何使用Mondo Rescue备份及恢复Linux系统(制作ISO镜像,成功恢复)

环境: CentOS Linux release 7.9.2009 mondoarchive v3.3.0-r3762 PVE 虚拟机 问题描述: 如何使用Mondo Rescue备份及恢复Linux系统, 制作ISO镜像, 整个系统将全部备份并恢复? Mondo Rescue是一个开源的备份和恢复工具,旨在提供快速、可靠的系统备份和恢复解决方案。…...

Java如何获取泛型类型

泛型&#xff08;Generic&#xff09; 泛型允许程序员在强类型程序设计语言中编写代码时使用一些以后才指定的类型&#xff0c;在实例化时作为参数指明这些类型。各种程序设计语言和其编译器、运行环境对泛型的支持均不一样。Ada、Delphi、Eiffel、Java、C#、F#、Swift 和 Vis…...

2023年【起重机械指挥】考试题及起重机械指挥找解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 起重机械指挥考试题考前必练&#xff01;安全生产模拟考试一点通每个月更新起重机械指挥找解析题目及答案&#xff01;多做几遍&#xff0c;其实通过起重机械指挥作业考试题库很简单。 1、【多选题】按照事故造成的人…...

【前端学java】Java中的接口和枚举概念(7)

theme: smartblue 往期回顾&#xff1a; 【前端学java】JAVA开发的依赖安装与环境配置 &#xff08;0&#xff09;【前端学 java】java的基础语法&#xff08;1&#xff09;【前端学java】JAVA中的packge与import&#xff08;2&#xff09;【前端学java】面向对象编程基础-类…...

P8611 [蓝桥杯 2014 省 AB] 蚂蚁感冒(模拟)

首先&#xff0c;我们自然而然的想到和 P1007独木桥 的机制是一样的&#xff0c; 我们只需要把蚂蚁的相遇并掉头视作互相穿过即可 标记向左&#xff0c;向右蚂蚁的数量 for (int i 0; i < num - 1; i){int temp 0;scanf("%d", &temp);// 向右移动if (tem…...

边缘计算是如何为元宇宙提供动力的?

构建元宇宙虚拟世界并不简单&#xff0c;也并不便宜&#xff0c;但是还是有许多大型公司正在转移大量资源来开发他们的元宇宙业务&#xff0c;当然大部分企业注意力都围绕着 VR 耳机、AR 眼镜、触觉手套和其他沉浸式虚拟现实体验所需的可穿戴硬件。虽然这种沉浸式的体验是最终结…...

优秀智慧园区案例 - 上海世博文化公园智慧园区,先进智慧园区建设方案经验

一、项目背景 世博文化公园是上海的绿色新地标&#xff0c;是生态自然永续、文化融合创新、市民欢聚共享的大公园。作为世博地区的城市更新项目&#xff0c;世博文化公园的建设关乎上海城市风貌、上海文化展示、城市生态环境、市民游客体验、上海服务品牌等&#xff0c;被赋予…...

【DevOps】Git 图文详解(五):远程仓库

Git 图文详解&#xff08;五&#xff09;&#xff1a;远程仓库 1.远程用户登录1.1 &#x1f511; 远程用户登录&#xff1a;HTTS1.2 &#x1f511; 远程用户登录&#xff1a;SSH 2.远程仓库指令 &#x1f525;3.推送 push / 拉取 pull4.fetch 与 pull 有什么不同 &#xff1f; …...

如果在手机没有root的情况下完成安卓手机数据恢复

您是否不小心从安卓设备中删除了重要数据&#xff1f; 担心如何取回您的照片、视频和文档&#xff1f; 有时您可能会不小心删除重要数据并使用安卓 root方法取回文件。 许多用户不喜欢根植他们的安卓设备&#xff0c;因为这是一种复杂的方法。 在本指南中&#xff0c;我们将向您…...

C++学习 --stack

目录 1&#xff0c; 什么是stack 2&#xff0c; 创建stack 2-1&#xff0c; 标准数据类型 2-2&#xff0c; 自定义数据类型 2-3&#xff0c; 其他创建方式 3&#xff0c; 操作stack 3-1&#xff0c; 赋值 3-2&#xff0c; 插入元素(push) 3-3&#xff0c; 查询元素 3…...

简单但好用:4种Selenium截图方法了解一下!

前言 我们执行UI自动化操作时&#xff0c;大多数时间都是不在现场的&#xff0c;出现错误时&#xff0c;没有办法第一时间查看到&#xff0c;这时我们可以通过截图当时出错的场景保存下来&#xff0c;后面进行查看报错的原因&#xff0c;Selenium中提供了几种截图的方法&#x…...

【报错记录】解决使用Kotlin写的SpringBoot项目使用Aspect切面无法生效的问题

前言 为了能在SpringBoot使用Kotlin&#xff0c;真的是各种坑都彩礼一遍&#xff0c;这次遇到的问题是Aspect无法对Kotlin代码生效。我这里的使用场景是使用切面切Controller中的方法&#xff0c;用来对接口进行一些初始化和收尾工作。 Aspect在Controller类还是Java代码的时…...

在python中分别利用numpy,tensorflow,pytorch实现数据的增加维度(升维),减少维度(降维)

文章目录 前言一、使用numpy实现升维度&#xff0c;降维度二、使用TensorFlow实现升维度&#xff0c;降维度三、使用PyTorch实现升维度&#xff0c;降维度总结 前言 我们明确一下升维和降维的概念&#xff1a; 升维&#xff08;Dimensionality Augmentation&#xff09;&…...

基于天鹰算法优化概率神经网络PNN的分类预测 - 附代码

基于天鹰算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于天鹰算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于天鹰优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神经网络的光滑…...

Flutter的Event Loop

Flutter 的事件循环机制是其框架的核心部分&#xff0c;它负责管理事件的处理和UI的渲染。了解这个机制对于开发高效且响应迅速的Flutter应用非常重要。以下是Flutter事件循环的主要组成部分和工作原理&#xff1a; 1. 主事件循环&#xff08;Main Event Loop&#xff09; 当…...

HarmonyOS ArkTSTabs组件的使用(六)

Tabs组件的使用 ArkUI开发框架提供了一种页签容器组件Tabs&#xff0c;开发者通过Tabs组件可以很容易的实现内容视图的切换。页签容器Tabs的形式多种多样&#xff0c;不同的页面设计页签不一样&#xff0c;可以把页签设置在底部、顶部或者侧边。 Tabs组件的简单使用 Tabs组件…...

【MetaLearning】有关Pytorch的元学习库higher的基本用法

【MetaLearning】有关Pytorch的元学习库higher的基本用法 文章目录 【MetaLearning】有关Pytorch的元学习库higher的基本用法1. 基本介绍2. Toy ExampleReference 1. 基本介绍 higher.innerloop_ctx是higher库的上下文管理器&#xff0c;用于创建内部循环&#xff08;inner lo…...

火山引擎 ByteHouse 的增强型数据导入技术实践

作为企业数字化建设的必备要素&#xff0c;易用的数据引擎能帮助企业提升数据使用效率&#xff0c;更好提升数据应用价值&#xff0c;夯实数字化建设基础。 数据导入是衡量OLAP引擎性能及易用性的重要标准之一&#xff0c;高效的数据导入能力能够加速数据实时处理和分析的效率。…...

展会营销实战指南:从精准获客到高效转化的全流程策略

1. 项目概述&#xff1a;从展台到订单的实战技能包如果你在B2B行业待过&#xff0c;或者负责过公司的市场推广&#xff0c;你一定对“展会”这个词又爱又恨。爱的是&#xff0c;它提供了一个短时间内集中接触大量潜在客户、建立品牌认知的绝佳机会&#xff1b;恨的是&#xff0…...

Go语言封装企业微信机器人:提升开发效率与构建可靠告警系统

1. 项目概述&#xff1a;一个企业微信机器人的轻量级封装如果你在企业里负责自动化流程、监控告警或者日常办公效率提升&#xff0c;大概率听说过或者用过企业微信的群机器人。官方提供的Webhook接口虽然简单直接&#xff0c;但用起来总感觉差点意思&#xff1a;发消息要自己拼…...

Linux内核调优笔记:调整tcp_sack与tcp_dsack参数,对高并发服务网络性能的实际影响测试

Linux内核TCP调优实战&#xff1a;SACK与D-SACK对高并发服务的性能影响量化分析 在游戏服务器、实时通信系统等高并发场景中&#xff0c;网络性能的细微差异可能直接导致用户体验的分水岭。当服务器需要处理数万并发连接时&#xff0c;TCP协议栈的默认配置往往成为性能瓶颈的隐…...

ESXi遗留快照删除教程:用1条命令彻底清理(附VMID查询)

在ESXi运维过程中&#xff0c;虚拟机快照遗留是常见问题——手动删除快照失败、快照文件残留、快照链异常等&#xff0c;都会导致遗留快照占用大量存储空间&#xff0c;甚至拖慢虚拟机和ESXi主机性能。很多运维小伙伴疑惑&#xff1a;如何高效删除遗留快照&#xff1f;核心方法…...

小红书运营自动化工具开发:从接口调用到风险规避的实战指南

1. 项目概述&#xff1a;一个面向小红书运营的自动化工具集最近在和一些做小红书内容运营的朋友交流时&#xff0c;发现他们普遍面临一个痛点&#xff1a;日常运营工作琐碎且重复&#xff0c;比如笔记发布、数据监控、评论互动、素材收集等&#xff0c;占据了大量时间。手动操作…...

避坑指南:Azure DevOps Server安装时,SQL Server版本兼容性和本地账户权限那些事儿

Azure DevOps Server安装深度避坑指南&#xff1a;SQL兼容性与权限配置实战解析 当你在企业级开发环境中首次部署Azure DevOps Server时&#xff0c;往往会遇到两个最棘手的"拦路虎"&#xff1a;SQL Server版本兼容性问题和本地账户权限配置。这两个问题看似简单&…...

Balena Etcher终极指南:三步搞定系统镜像烧录,新手也能轻松上手

Balena Etcher终极指南&#xff1a;三步搞定系统镜像烧录&#xff0c;新手也能轻松上手 【免费下载链接】etcher Flash OS images to SD cards & USB drives, safely and easily. 项目地址: https://gitcode.com/GitHub_Trending/et/etcher 你是否曾经为了给树莓派烧…...

在Taotoken平台如何清晰查看各模型用量与成本明细

在Taotoken平台如何清晰查看各模型用量与成本明细 1. 用量看板的核心功能 Taotoken平台的用量看板为接入多个大模型的用户提供了全面的用量观测能力。该功能位于控制台的"用量分析"模块&#xff0c;支持按API Key、模型类型和时间维度进行数据筛选。系统会记录每次…...

Flink + Iceberg实战:如何用流批一体架构实现分钟级数据入湖与实时查询?

Flink Iceberg实战&#xff1a;构建分钟级实时数据湖的完整指南 在数据驱动的时代&#xff0c;企业面临着海量实时数据处理与即时分析的挑战。传统Lambda架构需要维护两套独立的批处理和流处理系统&#xff0c;不仅资源消耗大&#xff0c;还带来了数据一致性和运维复杂性问题。…...

深入解析PX4无人机飞控系统:嵌入式实时系统架构与开发实战

深入解析PX4无人机飞控系统&#xff1a;嵌入式实时系统架构与开发实战 【免费下载链接】PX4-Autopilot PX4 Autopilot Software 项目地址: https://gitcode.com/gh_mirrors/px/PX4-Autopilot PX4-Autopilot作为开源无人机飞控领域的标杆项目&#xff0c;为开发者提供了完…...