antd4 Select 支持分页加载及搜索

实现原理:要支持分页,就是在下拉列表滚动到底的时候发起下一次请求,把请求数据push到现有的下拉框里面

const [options, changeOptions] = useState([])
  const [searchData, changeSearchData] = useState({
    pagination: {
      current: 1,
      pageSize: 10,
      total: 0
    },
    searchValue: ''
  })
  const { pagination: { current, pageSize, total }, searchValue } = searchData
  useEffect(() => {
    // 页码,及搜索值变化时,发请求
    const data = {
      current,
      pageSize,
      searchValue
    }
    request('/api/getList', data).then(res => {
      const { pagination, options } = res
      changeOptions(options)
      changeSearchData({ ...searchData, pagination })
    })
  }, [current, searchValue])
  const scrollEnd = (e) => {
    e.persist();
    const { target } = e;
    // 滚动 触底 看接口是否还有剩余的值没传过来
    if (target.scrollTop + target.offsetHeight === target.scrollHeight) {
      if (current * pageSize < total) {
        changeSearchData({
          ...searchData,
          pagination: {
            ...searchData.pagination,
            current: current + 1
          },
        })
      }
    }
  }
  // 搜索条件变化时,current变成1,
  const searchDataset = (value) => {
    changeSearchData({
      pagination: {
        ...searchData.pagination,
        current: 1
      },
      searchValue: value
    })
  }
  return (
    <Select
      showSearch={true}
      options={options}
      // options的值 搜索需要filterOption return true 保证过滤的数据是从接口取过来的
      filterOption={() => { return true }} 
      onPopupScroll={scrollEnd}
      onSearch={debounce(searchDataset, 500)} // 防止频繁触发请求
    >
    </Select>
  )


 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值