受控和非受控输入

来源:undefined 2025-01-11 02:25:18 0

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中文网其它相关文章!

最新文章