react ant design select 远程搜索,调用接口 显示 加载中,接口调用完毕,要是没有数据,显示暂无数据

javascript 复制代码
import { useState } from 'react';
import { Select, Spin } from 'antd';

const { Option } = Select;

const RemoteSearchSelect = () => {
  const [loading, setLoading] = useState(false);
  const [options, setOptions] = useState([]);

  const fetchData = async (value) => {
    setLoading(true);

    // 模拟调用接口获取数据
    try {
      const response = await fetch(`https://api.example.com/search?q=${value}`);
      const data = await response.json();

      if (data.length > 0) {
        setOptions(data);
      } else {
        setOptions([]);
      }
    } catch (error) {
      console.error('Error fetching data:', error);
    }

    setLoading(false);
  };

  const handleSearch = (value) => {
    // 远程搜索数据
    fetchData(value);
  };

  return (
    <Select
      showSearch
      onSearch={handleSearch}
      placeholder="搜索"
      notFoundContent={loading ? <Spin size="small" /> : options.length === 0 ? "暂无数据" : null}
    >
      {options.map((option) => (
        <Option key={option.value} value={option.value}>
          {option.label}
        </Option>
      ))}
    </Select>
  );
};

export default RemoteSearchSelect;
相关推荐
snakeshe10101 分钟前
深入理解useState:批量更新与非函数参数支持
前端
windliang1 分钟前
Cursor 排查 eslint 问题全过程记录
前端·cursor
boleixiongdi2 分钟前
# Bsin-App Uni:面向未来的跨端开发框架深度解析
前端
G等你下课5 分钟前
AJAX请求跨域问题
前端·javascript·http
前端西瓜哥6 分钟前
pixijs 的填充渲染错误,如何处理?
前端
snakeshe10106 分钟前
6-1. 实现 useState
前端
呆呆没有脑袋9 分钟前
深入浅出 JavaScript 闭包:从核心概念到框架实践
前端
snakeshe101010 分钟前
用100行代码实现React useState钩子:多状态管理揭秘
前端
爱编程的喵10 分钟前
JavaScript闭包深度解析:从作用域到实战应用
前端·javascript
ITfeib11 分钟前
Flutter
开发语言·javascript·flutter