React 应用中表单输入的关键概念:受控与非受控输入
受控输入
在受控输入模式下,组件状态完全掌控输入字段的值。 组件状态存储当前输入值,用户输入的任何更改都会更新组件状态,并立即反映在输入字段中。 这通常通过将输入元素的 value 属性设置为组件状态值,并使用 onChange 事件处理程序来更新状态实现。 受控输入是 React 表单处理的标准实践。
示例代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import React, { useState } from react;
function ControlledInputExample() {
const [inputValue, setInputValue] = useState();
const handleChange = (e) => {
setInputValue(e.target.value);
};
return (
<div>
<input type="text" value={inputValue} onChange={handleChange} />
<p>Current Value: {inputValue}</p>
</div>
);
}
非受控输入
非受控输入则相反,输入字段的值不由 React 状态直接管理。输入元素自身维护其状态。 React 无法直接控制输入值,获取值需要直接访问 DOM 元素(例如,使用 ref)。 这种方式在 React 中较少使用,但某些场景下可能适用,比如处理复杂的表单逻辑或与非 React 库集成。
示例代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
import React, { useRef } from react;
function UncontrolledInputExample() {
const inputRef = useRef(null);
const handleClick = () => {
console.log(inputRef.current.value);
};
return (
<div>
<input type="text" ref={inputRef} />
<button onClick={handleClick}>Get Value</button>
</div>
);
}
总结
受控输入将输入值直接与 React 状态绑定,实现 UI 和状态的高度同步,提供更精细的控制。非受控输入则由 DOM 或其他库管理状态,React 需要间接访问其值。 通常情况下,推荐使用受控输入,因为它更符合 React 的声明式编程范式,并提供更好的可预测性和可维护性。
以上就是受控和非受控输入的详细内容,更多请关注php中文网其它相关文章!