react如何实现表格多条件搜索

 更新时间:2024年03月14日 14:16:28   作者:代码真的养发  
这篇文章主要介绍了react如何实现表格多条件搜索问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

react实现表格多条件搜索

  • 创建一个React组件来渲染表格及搜索功能。可以使用函数式组件或者类组件。
  • 在组件的状态中定义搜索条件的值。可以使用useState钩子函数来定义和更新搜索条件的状态。
  • 在组件中创建一个表单,包含多个输入框或下拉列表等用于输入搜索条件的表单元素。
  • 为每个表单元素绑定onChange事件处理程序,以便在输入框内容发生改变时更新相应的搜索条件值。
  • 定义一个函数,用于处理表单的提交事件。在该函数中获取搜索条件的值,并将其传递给数据源,进行过滤。
  • 在组件的render方法中,根据搜索条件对数据源进行过滤,并渲染符合条件的数据到表格中。
import React, { useState } from 'react';
 
const TableWithSearch = () => {
  const [searchValue1, setSearchValue1] = useState('');
  const [searchValue2, setSearchValue2] = useState('');
 
  const handleSearch = (e) => {
    e.preventDefault();
    // 根据搜索条件对数据源进行过滤处理
    // 这里只是一个示例,实际操作可能需要结合你的数据源和业务需求进行具体实现
    // filteredData是一个经过搜索条件过滤后的数据数组
    const filteredData = dataSource.filter(item => {
      return item.field1.includes(searchValue1) && item.field2.includes(searchValue2);
    });
 
    // 渲染表格
    renderTable(filteredData);
  }
 
  const renderTable = (data) => {
    // 渲染表格逻辑,根据传入的数据渲染表格
  }
 
  return (
    <div>
      <form onSubmit={handleSearch}>
        <input type="text" value={searchValue1} onChange={(e) => setSearchValue1(e.target.value)} />
        <input type="text" value={searchValue2} onChange={(e) => setSearchValue2(e.target.value)} />
        <button type="submit">搜索</button>
      </form>
      {renderTable(dataSource)}
    </div>
  );
}
 
export default TableWithSearch;

react查询、搜索类功能的实现

查询之类的如果是通过向列表接口中发送对应参数来查询的,那么在默认输出时,在useEffect钩子中的请求中可以先为需要查询的请求参数设初始的state,也就是null或者未定义,这样的话初始请求的还是整个列表,然后将这些state放入useEffect的依赖中,也就是第二个参数的数组中,然后在一些查询相关的组件中,如下拉选项、Search搜索框、时间选择器等,具体根据可查询项决定,然后更新初始设置的state,set为在这些组件的事件函数中将组件筛选的最终值。

因为useEffect监听到了这些状态发生的变化,所以重复执行了,重新调用了接口并传递了筛选参数,列表状态也发生了改变,就完成了查询的功能。

以下为下拉选项实例:

请求函数部分:

 const [tableList, setTableList] = useState([]);
 const [status, setStatus] = useState();
 const [title, setTitle] = useState();
useEffect(() => {
   axios.get('http://crmeb.kuxia.top/adminapi/cms/category',{
   	 status: status,
   	 title: title
   	}).then((res) => {
      setTableList(res.data.list);
    });
  }, [status, title]);//将sataus设为依赖
<Select
   options={[
       { label: '全部', value: null },
       { label: '显示', value: 1 },
       { label: '不显示', value: 0 },
    ]}
     onChange={(value) => {
         setStatus(value);//更改了status的状态触发了useEffect重新执行并发送了状态参数完成筛选查询
      }}/>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解决React Native端口号修改的方法

    解决React Native端口号修改的方法

    这篇文章主要介绍了解决React Native端口号修改的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • React中setState同步异步场景的使用

    React中setState同步异步场景的使用

    本文主要介绍了React中setState同步异步场景的使用,文中根据实例编码详细介绍的十分详尽,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • react 路由Link配置详解

    react 路由Link配置详解

    本文主要介绍了react 路由Link配置详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • Reactjs 错误边界优雅处理方法demo

    Reactjs 错误边界优雅处理方法demo

    这篇文章主要为大家介绍了Reactjs 错误边界优雅处理方法demo,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • React Hook中的useEffecfa函数的使用小结

    React Hook中的useEffecfa函数的使用小结

    React 会在组件更新和卸载的时候执行清除操作, 将上一次的监听取消掉, 只留下当前的监听,这篇文章主要介绍了React Hook useEffecfa函数的使用细节详解,需要的朋友可以参考下
    2022-11-11
  • 解决React初始化加载组件会渲染两次的问题

    解决React初始化加载组件会渲染两次的问题

    这篇文章主要介绍了解决React初始化加载组件会渲染两次的问题,文中有出现这种现象的原因及解决方法,感兴趣的同学跟着小编一起来看看吧
    2023-08-08
  • React反向代理及样式独立详解

    React反向代理及样式独立详解

    这篇文章主要介绍了React反向代理及样式独立详解,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-08-08
  • React与Redux之数组处理讲解

    React与Redux之数组处理讲解

    这篇文章主要介绍了React与Redux之数组处理讲解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • React深入了解原理

    React深入了解原理

    React是用于构建用户界面的JavaScript库, [1]  起源于Facebook的内部项目,该公司对市场上所有 JavaScript MVC框架都不满意,决定自行开发一套,用于架设Instagram的网站
    2022-07-07
  • React合成事件原理解析

    React合成事件原理解析

    事件是在编程时系统内发生的动作或者发生的事情,而开发者可以某种方式对事件做出回应,而这里有几个先决条件,这篇文章主要介绍了React合成事件原理解析,需要的朋友可以参考下
    2022-07-07

最新评论