为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 reactJS 中添加多个相同的字段表单?

如何在 reactJS 中添加多个相同的字段表单?

元芳怎么了 2022-07-08 17:45:30
我想在我的表单中动态添加多个人。就像我有第 1 个人的用户名和电子邮件一样,当我单击添加个人时,它应该在同一页面上为第 2 个人创建相同的字段。当我单击提交按钮时,它应该给我所有人的对象。应用程序.jsimport './App.css';import React, { Component } from 'react'import PropTypes from 'prop-types'export default class App extends Component {  state = {    fields:[]  };  addPerson() {    this.setState({fields:[...this.state.fields, ""]})  };  handleChange(e, index) {    this.state.fields[index] = e.target.value;     this.setState({fields: this.state.fields});  }  handleSubmit(e) {    console.log(this.state,"$$")  }  render() {    return (      <div className="App">      <header className="App-header">      <div>            <h1>The Form</h1>            {                this.state.fields.map((field, index) => {                  return(                    <div key={index}>                        <input onChange={(e)=>this.handleChange(e, index)} value={field}/>                    </div>                )              }              )            }            <button onClick={(e) => this.addPerson(e)}>Add Person</button>            <button onClick={(e) => this.handleSubmit(e)}>Submit</button>        </div>      </header>    </div>    )  }}我希望我的状态是这样的...... state = {    fields:[      {        id: 1,        name: 'Max',        email: 'max.max@max.in'      }    ]  };
查看完整描述

1 回答

?
DIEA

TA贡献1820条经验 获得超3个赞

我想在我的表单中动态添加多个人。就像我有第 1 个人的用户名和电子邮件一样,当我单击添加个人时,它应该在同一页面上为第 2 个人创建相同的字段。当我单击提交按钮时,它应该给我所有人的对象。


应用程序.js


import './App.css';


import React, { Component } from 'react'

import PropTypes from 'prop-types'


export default class App extends Component {


  state = {

    fields:[]

  };


  addPerson() {

    this.setState({fields:[...this.state.fields, ""]})

  };


  handleChange(e, index) {

    this.state.fields[index] = e.target.value; 

    this.setState({fields: this.state.fields});

  }


  handleSubmit(e) {

    console.log(this.state,"$$")

  }


  render() {

    return (

      <div className="App">

      <header className="App-header">

      <div>

            <h1>The Form</h1>

            {

                this.state.fields.map((field, index) => {

                  return(

                    <div key={index}>

                        <input onChange={(e)=>this.handleChange(e, index)} value={field}/>

                    </div>

                )

              }

              )

            }

            <button onClick={(e) => this.addPerson(e)}>Add Person</button>

            <button onClick={(e) => this.handleSubmit(e)}>Submit</button>

        </div>

      </header>

    </div>

    )

  }

}

我希望我的状态是这样的......


 state = {

    fields:[

      {

        id: 1,

        name: 'Max',

        email: 'max.max@max.in'

      }

    ]

  };


查看完整回答
反对 回复 2022-07-08
  • 1 回答
  • 0 关注
  • 213 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号