react 组件双向绑定

1. 使用 state 实现双向绑定

对于双向绑定,需要同时处理表单元素的`value`属性(通过`state`来设置)和`onChange`事件(用于更新`state`)。

javascript 复制代码
import { useState } from "react";

const MyComponent = () => {

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

  const handleChange = (e) => {

    setInputValue(e.target.value);

  };

  return (

    <div>

      <input type="text" value={inputValue} onChange={handleChange} />

      <p>You entered: {inputValue}</p>

    </div>

  );

};

2. 多个表单元素的双向绑定

例如表单中有多个输入框,可以为每个表单元素创建一个独立的状态变量,或者使用一个对象来存储所有表单元素的值。

javascript 复制代码
import { useState } from "react";

const MyFormComponent = () => {

  const [formData, setFormData] = useState({

    name: "",

    email: "",

  });

  const handleChange = (e) => {

    const { name, value } = e.target;

    setFormData({

      ...formData,

      [name]: value,

    });

  };

  const handleSubmit = (e) => {

    e.preventDefault();

    console.log("Form submitted:", formData);

  };

  return (

    <form onSubmit={handleSubmit}>

      <input

        type="text"

        name="name"

        value={formData.name}

        onChange={handleChange}

      />

      <input

        type="email"

        name="email"

        value={formData.email}

        onChange={handleChange}

      />

      <button type="submit">Submit</button>

    </form>

  );

};
相关推荐
006_2 分钟前
Java8的lambda用法总结
前端·数据库
minglie15 分钟前
mqtt接入事件回调测试
前端·javascript
Luna-player21 分钟前
Webpack vs Vite
前端·vue.js·webpack
我是初九22 分钟前
【遇见狂神说|前端】HTML5
前端·html
Cg1362691597425 分钟前
js引入方式
前端·javascript·ajax
J超会运29 分钟前
从零部署Nginx:Web全栈实战指南
运维·前端·nginx
-SOLO-36 分钟前
chrome插件 将网页转化为markdown
前端·chrome
酉鬼女又兒41 分钟前
零基础入门Web应用开发(备赛蓝桥杯)_网页布局原理
前端·职场和发展·蓝桥杯·html5
zhaoyin199442 分钟前
JavaScript面试题笔记
java·javascript·笔记
zzh0811 小时前
web技术与nginx网站环境部署
运维·前端·nginx