亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在 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: '[email protected]'      }    ]  };
查看完整描述

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: '[email protected]'

      }

    ]

  };


查看完整回答
反對 回復 2022-07-08
  • 1 回答
  • 0 關注
  • 209 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號