🙂博主:小猫娃来啦
🙂本文核心:React写法——使用js高阶函数实现多条件搜索功能
目录
思考一下
前端搜索是很常见的功能,各种网页,后台管理系统都会频繁出现这一功能。能否有一种最为精妙的方式实现这一功能呢?
⭐首先我用了一下csdn官网的搜索这个搜索也是非常好用,是button按钮的形式来点击控制搜索。
但还有一种搜索是用input事件做的搜索,一边搜索一边显示数据,这种搜索个人感觉比较舒服一点。
但无论是哪种搜索,实现思路其实是一样的。
代码是什么?你如何看待编程语言?
⭐每个人都有不同的回答。为此我问卷了很多人,最终得到一个比较接近本源的回答。
这段回答是这样的:
人类有人类的语言,计算机有计算机的语言。计算机的语言从二进制开始,一直是以0和1的排列组合形成的语言,很难去描述一种东西,很难让人接受。故而有了编程语言,编程语言存在的意义就是为了让程序好描述,让人们好理解。同样一个功能,一百人写,可能有一百种写法。
所以今天我们用尽可能最简单的方式去实现前端搜索功能。
用react写法来实现,思路+步骤:
第一步:准备数据
首先,需要创建一段假数据,模拟后端接口返回的数据。
后端数据是这样的(以MySql数据库为例):
这是可视化的后端数据表,上面这个表的表头是字段,下面的数据是字段对应的值。
前端请求后端接口,返回的数据是这样的(一般是数组包对象的形式):所以我们设计的假数据,应当和接口请求的数据格式相同,也是数组包对象的形式。
所以最终我们设计的数据如下:
const res = [ { id: 1, name: '张温', age: '19', gender: '男' }, { id: 2, name: '张三丰', age: '38', gender: '男' }, { id: 3, name: '张无忌', age: '25', gender: '男' }, { id: 4, name: '王无维', age: '25', gender: '男' }, { id: 5, name: '马云禄', age: '17', gender: '女' }, { id: 6, name: '黄月英', age: '17', gender: '女' }, ]
第二步:根据数据结构渲染Dom
⭐这一步,我们要根据数据接口,看看要设计几个搜索框。
根据第一步我们设计的数据,我们需要设计三个搜索框。并引入表格组件将数据渲染到表格种。我们先声明三个变量:
data
变量用来接收存放数据,list
变量用来渲染数据,search
变量用来数据搜索
const [data, setData] = useState([]) const [list, setList] = useState([]) const [search, setSearch] = useState({ name: ``, age: ``, gender: null, })
渲染数据,我们需要引入组件,最终做法如下
return ( <> <Alert message="用户管理" type="success" closable /> <br /> <Space wrap> <Space align="center"> 姓名: <Input value={search.name} onChange={(v) => setSearch({ ...search, name: v.target.value })} placeholder="请输入姓名" /> </Space> <Space align="center"> 年龄: <Input value={search.age} onChange={(v) => setSearch({ ...search, age: v.target.value })} placeholder="请输入年龄" /> </Space> <Space align="center"> 性别: <Select value={search.gender} onChange={(v) => setSearch({ ...search, gender: v })} placeholder="请输入性别" options={[ { value: '男', label: '男', }, { value: '女', label: '女', }, ]} style={{ width: 180, }} /> </Space> <Space align="center"> <Button type="primary" onClick={handleSearch}> 搜索 </Button> <Button onClick={() => { setList(data) setSearch({ name: ``, age: ``, gender: null, }) }} > 重置 </Button> </Space> </Space> <Table rowKey="id" columns={[ { title: '姓名', dataIndex: 'name', }, { title: '年龄', dataIndex: 'age', }, { title: '性别', dataIndex: 'gender', }, ]} dataSource={list} /> </> )
⭐展示效果是这样:
第三步:处理筛选条件
因为我们的数据只有三个字段,即 姓名,年龄,性别。所以我们可以最大设置三个搜索框,也就是三个搜索条件。
如果我们的数据有n个字段,那么我们可以最大设置n个搜索框,也就是n个搜索条件。
这里需要注意,搜索姓名时,比如我们输入张三,那么应该得到和张三有关的所有数据。
如果在此基础上,我们输入18岁,则应以上面筛选的结果为基础,再筛选18岁。此时就是两个条件。
以此类推,可以由多个条件。
也就是说,这里最核心的是,一定是对原数据进行处理。
满足条件1 ===>得到结果1(深拷贝的数据源第一次筛选处理得到的结果1)
满足条件2 ===>得到结果2(以结果1为数据源再筛选条件2得到结果2)
。。。。。。
条件之间是交集关系
最终我们这样操作数据:
data.filter((item) =>search.name ? item.name.includes(search.name) : true) .filter((item) =>search.age ? item.age.includes(search.age) : true) .filter((item) =>search.gender ? item.gender === search.gender : true)
那么事情到这就做完了,我们看一下效果:
react写法实现前端搜索功能(完整代码)
因为这里是react项目,所以我直接将本功能以及代码打包成了资源上传。
需要研究的可以等资源上传成功下载学习。说明一下:
下载后,需要终端执行命令:
npm install -g create-react-app,全局安装react脚手架工具
npm i,安装依赖
npm run dev运行项目
有不明白的,欢迎评论区留言讨论。如果本文解决了你的问题,对你有帮助,还望不吝三连🙂🙂🙂