React搜索框组件

题目要求

实现一个search input组件,用户输入任意内容后自动触发关键词api搜索需求:搜索不频繁触发,结果响应及时

解答

下面仅给出React中防抖的实现,竞态请求的问题可以使用AbortController

javascript 复制代码
import { useState, useRef, useCallback, useEffect } from "react";

const fetchApi = (input) => {
  console.log(`fetch ${input}...`);
};

const useDebounce = function (fun, timeout) {
  const timerRef = useRef(null);
  const funRef = useRef(fun);
  funRef.current = fun;

  return useCallback(
    function (...args) {
      clearTimeout(timerRef.current);
      timerRef.current = setTimeout(() => {
        funRef.current.apply(this, args);
      }, timeout);
    },
    [timeout]
  );
};

export default function SearchInput() {
  const [value, setValue] = useState("");

  const search = useDebounce(fetchApi, 1000);

  const handleChange = (e) => {
    setValue(e.target.value);
    search(e.target.value);
  };

  return <input value={value} onChange={handleChange} />;
}

codesandbox链接:https://codesandbox.io/p/sandbox/ftgm5k

相关推荐
姓王者1 小时前
Cloudflare Pages自定义依赖安装实践 | 姓王者的博客
前端
stringwu1 小时前
Flutter 开发的 AI 三件套:壮汉、法师、实习生
前端
代码搬运媛1 小时前
BFF 架构浅析:再也不用求后端改接口了
前端
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_50:(深入理解 DOM 中的 Text 节点)
前端·javascript·microsoft·ui·html·媒体
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_51:(深入理解 XPathEvaluator 接口)
前端·javascript·ui·html·音视频
wjykp1 小时前
5.cypher语句组合与复杂操作
linux·前端·javascript
梦无矶1 小时前
nrm自动设置npm镜像源
前端·npm·node.js
鲤鱼_5992 小时前
记录——前端开发IDEA需要的插件
前端
摘星编程2 小时前
基于 JiuwenSwarm AgentTeam 构建混沌工程自动化实战
前端·chrome