背景
假设我们都知道debounce
来自的函数lodash
。
如果用户快速输入1
, 12
, 123
, 1234
,它允许我们1234
在一定的延迟时间后只进行一次警报,带有。
这非常用于减少请求量,用于优化。
描述
对于普通的输入字段,我们可以使用那种,debounce
并且它可以工作。
问题:一旦我们setState
在同一个回调中添加了debounce
,debounce
就无法正常工作。
有谁知道原因?
import React, { useState } from "react";
import "./styles.css";
import { debounce } from "lodash";
export default function App() {
const [input, setInput] = useState("");
const debouceRequest = debounce(value => {
alert(`request: ${value}`);
}, 1000);
const onChange = e => {
setInput(e.target.value); // Remove this line will lead to normal debounce
debouceRequest(e.target.value);
};
return (
<div className="App">
<input onChange={onChange} />
</div>
);
}