React 实现输入框input的双向数据绑定

1. 实现效果

input输入框显示的是state中的数据,state改变,input输入框中的值也跟着改变:

手动更改输入框的值,state也会相应改变:

2. 实现过程

使用 React-Hook,首先定义渲染input输入框值的state,初始值为空:

const [inputValue, setInputValue] = useState('');

然后在input输入框中添加value属性,属性值为inputValue,由inputValue决定显示的内容。

<input type="text" className="inputDemo" value={inputValue} />

然而浏览器会报出警告,意思是给input添加了value属性,必须再加上onChange 或者readOnly属性,要么就将 value 改为defaultValue

Warning: You provided a value prop to a form field without an onChange handler. This will render a read-only field. If the field should be mutable use defaultValue. Otherwise, set either onChange or readOnly.

要实时显示inputValue的内容,当然不能设置为defaultValue,也不能设置只读readOnly,所以加上onChange事件,里面定义一个函数,功能为根据inputvalue改变状态:

<input
	type="text"
	className="inputDemo"
	value={inputValue}
	onChange={e => {
		setInputValue(e.target.value);
	}}
/>

onChange里面的函数,接受事件对象为参数,通过事件对象,可以拿到当前的value

3. 完整代码

import { useState } from 'react';
import './index.css';

const Demo = () => {
    const [inputValue, setInputValue] = useState('');
    return (
        <>
            <input
                type="text"
                className="inputDemo"
                value={inputValue}
                onChange={e => {
                    setInputValue(e.target.value);
                }}
            />
        </>
    );
};

export default Demo;

📘📘欢迎在我的博客上访问:
https://lzxjack.top/

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

火星飞鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值