React写法——使用js高阶函数实现多条件搜索功能

简介: React写法——使用js高阶函数实现多条件搜索功能


🙂博主:小猫娃来啦

🙂本文核心: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运行项目


有不明白的,欢迎评论区留言讨论。如果本文解决了你的问题,对你有帮助,还望不吝三连🙂🙂🙂


相关文章
|
10天前
|
编解码 前端开发 JavaScript
js react antd 实现页面低分变率和高分变率下字体大小自适用,主要是配置antd
在React中结合Ant Design与媒体查询,通过less变量和响应式断点动态调整`@font-size-base`,实现多分辨率下字体自适应,提升跨设备体验。
32 2
|
5月前
|
JSON 前端开发 算法
掌握Multi-Agent实践(三):ReAct Agent集成Bing和Google搜索功能,采用推理与执行交替策略,增强处理复杂任务能力
掌握Multi-Agent实践(三):ReAct Agent集成Bing和Google搜索功能,采用推理与执行交替策略,增强处理复杂任务能力
306 23
|
6月前
|
前端开发 JavaScript NoSQL
使用 Node.js、Express 和 React 构建强大的 API
本文详细介绍如何使用 Node.js、Express 和 React 构建强大且动态的 API。从开发环境搭建到集成 React 前端,再到利用 APIPost 高效测试 API,适合各水平开发者。内容涵盖 Node.js 运行时、Express 框架与 React 库的基础知识及协同工作方式,还涉及数据库连接和前后端数据交互。通过实际代码示例,助你快速上手并优化应用性能。
|
6月前
|
JavaScript
JS实现多条件搜索函数
JS封装的多条件搜索
|
7月前
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
11月前
|
前端开发 JavaScript 测试技术
React 中集成 Chart.js 图表库
本文介绍了如何在 React 项目中集成 Chart.js 创建动态图表,涵盖基础概念、安装步骤、代码示例及常见问题解决方法,帮助开发者轻松实现数据可视化。
304 11
|
11月前
|
资源调度 前端开发 数据可视化
构建高效的数据可视化仪表板:D3.js与React的融合之道
【10月更文挑战第25天】在数据驱动的时代,将复杂的数据集转换为直观、互动式的可视化表示已成为一项至关重要的技能。本文深入探讨了如何结合D3.js的强大可视化功能和React框架的响应式特性来构建高效、动态的数据可视化仪表板。文章首先介绍了D3.js和React的基础知识,然后通过一个实际的项目案例,详细阐述了如何将两者结合使用,并提供了实用的代码示例。无论你是数据科学家、前端开发者还是可视化爱好者,这篇文章都将为你提供宝贵的洞见和实用技能。
290 5
|
11月前
|
JavaScript 前端开发 开发者
JavaScript框架React vs. Vue:一场性能与易用性的较量
JavaScript框架React vs. Vue:一场性能与易用性的较量
243 0
|
设计模式 前端开发 数据可视化
【第4期】一文了解React UI 组件库
【第4期】一文了解React UI 组件库
684 0
|
资源调度 前端开发 JavaScript
React 的antd-mobile 组件库,嵌套路由
React 的antd-mobile 组件库,嵌套路由
371 0

热门文章

最新文章