react js 处理表单( form )的2个例子

起因, 目的:

表单其实,有点复杂,因为涉及事件,event.

不熟悉的代码,还是尽量手写,不然的话,AI 生成的东西,自己看不懂。

例1 普通, 直接的方法

一个输入框,一个处理函数。

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

// 使用 form, 表单
function App() {
  const [username, setUsername] = useState("friend!");
  const [password, setPassword] = useState("123!");

  function handleUsernameChange(event) {
  
    // 理解 event.target.value
    // target 是 input 标签,
    // value  是用户输入的值
    // 同理,还可以打印出其他属性,
    // 如 event.target.name, event.target.type 等
    console.log("Username changed: ", event.target.value);
    // console.log("event.target.name: ", event.target.name);
    // console.log("event.target.type: ", event.target.type);
  }

  function handlePasswordChange(event) {
    console.log("Password changed: ", event.target.value);
  }

  return (
    <form>
      <input type="text" name="username" placeholder="Your name" onChange={handleUsernameChange} />
      <input type="password" name="password" placeholder="Password" onChange={handlePasswordChange} />
    </form>
  );
}

export default App;

onChange 这个函数确实很有用,用户调试代码很不错。

例2 用一个函数来处理表单
python 复制代码
import { useState } from "react";

// 使用 form, 表单
function App() {
  
  // 用一个 state 来处理整个表单。
  const [formData, setFormData] = useState({username: "", password: ""});

  console.log("formData changed: ", formData);

  function handleChange(event) {
    setFormData(prevFormData => {

      return {
        ...prevFormData,  // 复制 prevFormData 对象

        // 这里如果不加 [] 会报错。
        // [event.target.name] 表示动态计算出这个字段的名字, 作为对象的 key
        [event.target.name]: event.target.value  // 更新对应字段
      }

    })
  }

  // 如果要使用 一个函数来处理表单,每个字段都加上 name 属性
  return (
    <form>
      <input type="text" name="username" placeholder="Your name" onChange={handleChange} />
      <input type="password" name="password" placeholder="Password" onChange={handleChange} />
    </form>
  );
}

export default App;

结论 + todo

走过路过,支持一下啊。

相关推荐
摘星编程12 分钟前
React Native鸿蒙版:Drawer抽屉导航实现
react native·react.js·harmonyos
东东51627 分钟前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino31 分钟前
图片、文件的预览
前端·javascript
2501_920931702 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05282 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔3 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李3 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN3 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒3 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库3 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css