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>

  );

};
相关推荐
w_t_y_y17 分钟前
vue父子组件通信(二)祖先调用inject
前端·javascript·vue.js
哆哆啦0018 分钟前
URL 重写规则和静态资源解析逻辑
前端·浏览器·url
wkj00119 分钟前
JavaScript模块化技术进程详解
开发语言·javascript·ecmascript
IT_陈寒19 分钟前
Java的Stream.peek()千万别乱用,血泪教训
前端·人工智能·后端
w_t_y_y20 分钟前
VUE组件配置项(二)data和props
前端·javascript·vue.js
Martin -Tang29 分钟前
uniapp+vue3+ts自定义表格
javascript·vue.js·uni-app
问心无愧051334 分钟前
ctf show web入门 89
android·前端·笔记
hexu_blog35 分钟前
前端vue后端java+springboot如何显示视频压缩
前端·vue.js·vue压缩视频·java压缩视频·指定大小压缩视频
欧阳天风43 分钟前
electron播放本地音乐的问题
前端·javascript·electron
艾伦野鸽ggg1 小时前
CSS布局与动效知识梳理
前端·css