【React】使用lodash的debounce未生效

react中直接使用lodash的debounce函数,发现并未生效,1秒内多次触发,控制台仍有多次打印,这是因为debounceSearch函数被重新定义了,需要使用useCallback来包装函数。

javascript 复制代码
import { ChangeEvent } from "react"
import { useCallback, useState } from "react"
import { Input } from "antd"
import _ from "lodash"

export default () => {
	const [idValue, setIdValue] = useState<string>("")
	const debounceSearch = _.debounce((value) => {
	    console.log(value)
	  }, 1000)
	)
	const onIptChange = (e: ChangeEvent<HTMLInputElement>) => {
	  debounceSearch(e.target.value)
	}

	return <Input value={idValue} onChange={onIptChange}/>
}

使用useCallback,可以将这个函数缓存起来,避免重复定义。

javascript 复制代码
const debounceSearch = useCallback(
  _.debounce((value) => {
    console.log(value)
  }, 1000),
  []
)
相关推荐
Tzarevich几秒前
React 中的 JSX 与组件化开发:以函数为单位构建现代前端应用
前端·react.js·面试
李香兰lxl1 分钟前
A I时代如何在研发团队中展现「前端」的魅力
前端
本末倒置1831 分钟前
解决 vue2.7使用 pnpm 和 pinia 2.x报错
前端
CoderLiz2 分钟前
Flutter中App升级实现
前端
别急国王3 分钟前
React Hooks 为什么不能写在判断里
react.js
Mintopia3 分钟前
⚛️ React 17 vs React 18:Lanes 是同一个模型,但跑法不一样
前端·react.js·架构
李子烨3 分钟前
吃饱了撑的突发奇想:TypeScript 类型能不能作为跑业务逻辑的依据?(纯娱乐)
前端·typescript
AAA简单玩转程序设计3 分钟前
救命!Java小知识点,基础党吃透直接起飞
java·前端
叫我詹躲躲4 分钟前
Vue 3 动态组件详解
前端·vue.js
叫我詹躲躲4 分钟前
基于 Three.js 的 3D 地图可视化:核心原理与实现步骤
前端·three.js