los*_*193 6 debouncing reactjs react-hook-form
我使用react-hook-forms 设置了以下受控组件。
<Controller
control={control}
name={"test"}
render={({ field: { onChange, value, name } }) => (
<Dropdown
name={name}
value={value}
handleChange={onChange}
options={foodCategories()}
/>
)}
/>
Run Code Online (Sandbox Code Playgroud)
我想调用防抖功能,并且尝试执行以下操作:
handleChange={debounce(onChange, 500)}
Run Code Online (Sandbox Code Playgroud)
但我不断收到错误抛出:
This synthetic event is reused for performance reasons, Objects are not valid as a React child (found: object with keys {dispatchConfig, _targetInst, nativeEvent, type, target, currentTarget, eventPhase, bubbles, cancelable,
Run Code Online (Sandbox Code Playgroud)
如何在受控反应钩子表单组件上调用去抖?
dir*_*ory -6
这可以通过以下实现来实现;
<Controller
name={fieldName}
rules={{ required: `errors.${fieldName}.required` }}
render={({ field, fieldState: { error } }) => (
<input
type="text"
error={error && t(`${error.message}`)}
onChange={debounce((e) => field.onChange(e), 50)}
defaultValue={field.value}
/>
)}
/>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7540 次 |
| 最近记录: |