React查询、搜索类功能的实现
2023-12-14 21:41:49
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重新执行并发送了状态参数完成筛选查询
}}/>
文章来源:https://blog.csdn.net/qq_21861771/article/details/134882952
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!