无法解构“ e.target”的属性“名称”,因为其未定义

时间:2020-06-17 19:53:30

标签: javascript reactjs

我收到一些错误消息,因为无法在createform()方法中未定义属性“ e.target”的属性“名称”,因此无法对其进行分解。我不明白为什么会得到它,并且我突出显示了导致错误的行。

import React from 'react';
import { Card, Container, Row, Button, Form, Col } from 'react-bootstrap';
import Select from 'react-select';

class Items extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
             itemNames: '',
             formdata: [{itemname: '', quantity: '', rate: '', unit: ''}]
        }
    }

    async handleItems() {
        const url = '/ItemNames'
        const res = await fetch(url, {
                method: 'GET',
                headers: {
                    'Content-Type' : 'application/json',
                },
        })

        const json = await res.json()
        let arr = []
        for(let i = 0; i < json.length; i++) {
            let obj = json[i].name
            arr.push({label: obj})
        }
        await this.setState({itemNames: arr})
    }

    componentDidMount() {
        this.handleItems()
    }


    handleChange(i, e) {
        console.log(i)
        console.log(e)
        const {name, value} = e.target
        let formdata = [...this.state.formdata]
        formdata[i] = {...formdata[i], [name]: value}
        this.setState({formdata})
    }

  handleAdd() {
        this.setState(prevState => ({
            formdata: [...prevState.formdata, {itemname: '', quantity: '', rate: '', unit: ''}]
        }))
    }

    createform() {
        return this.state.formdata.map((el, i) => (
            <div key={i}>
                <Card className='mb-2'>
                    <Card.Body>
                        <Row className='mb-2'>
                            <Col>
                                <Form.Group controlId="formBasicSize" className = 'form-group'>
                                    <Form.Label style={{fontWeight:'bold'}}>Item {i+1}</Form.Label>
                                  **<Select value={el.itemname} name='itemname' onChange={this.handleChange.bind(this, i)} placeholder="Enter a Item Name"  type="text" required options = {this.state.itemNames}/> //Getting error here**
                                </Form.Group>
                            </Col>

                            <Col>
                                <Form.Group controlId="formBasicSize" className = 'form-group'>
                                    <Form.Label style={{fontWeight:'bold'}}>Rate (in Rupees)</Form.Label>
                                    <Form.Control value = {el.rate} name = 'rate' onChange={this.handleChange.bind(this, i)} type="text" placeholder="Enter a number"/>
                                </Form.Group>
                            </Col>
                        </Row>

                        <Row className='mb-2'>
                            <Col>
                                <Form.Group controlId="formBasicSize" className = 'form-group'>
                                    <Form.Label style={{fontWeight:'bold'}}>Quantity</Form.Label>
                                    <Form.Control value = {el.quantity} name = 'quantity' onChange={this.handleChange.bind(this, i)} required type="text" placeholder="Enter a number"/>
                                </Form.Group>
                            </Col>

                            <Col>
                                <Form.Group controlId="formBasicSize" className = 'form-group'>
                                    <Form.Label style={{fontWeight:'bold'}}>Quantity Unit</Form.Label>
                                    <Form.Control value = {el.unit} name = 'unit' onChange={this.handleChange.bind(this, i)} required type="text" placeholder="Enter"/>
                                </Form.Group>
                            </Col>
                        </Row>

                        <Row style={{justifyContent: 'center'}} className='mb-1'>
                            <Button variant="danger" size="sm" className="btn" onClick={this.handleRemove.bind(this, i)}>
                                Remove Item
                            </Button>
                        </Row>
                    </Card.Body>
                    </Card>
            </div>
        ))
    }

    render() {

  let { formdata } = this.state
  return(
    <Container>

      <Form className = 'form'>

        {this.createform()}

        <Row className='mt-3 mb-2'>
          <Col>
            <Button variant="primary" className="btn" onClick={this.handleAdd.bind(this)}>
              Add Item
                  </Button>
              </Col>
            </Row>

            <Row className='mt-3 mb-2'>
              <Col>
                  <Button variant="primary" className="btn" block onClick={this.handleSubmit}>
                  Submit
                </Button>
              </Col>
            </Row>

            </Form>

          </Container>

        )
    }
}

export default {Items}

请让我知道为什么事件未定义,因为在调用handleChange时,事件在其他输入中是相同的,但在Select输入中却未定义

1 个答案:

答案 0 :(得分:0)

我不熟悉以下语法:const {name, value} = e.target

您可能希望将代码包装在if语句中,以避免出现错误:

if(e && e.target) {
    let formdata = [...this.state.formdata]
    formdata[i] = {...formdata[i], [e.target.name]: e.target.value}
    this.setState({formdata})
}

现在查看它,我不确定e.target.name是否有意义。不确定是否要使用name变量。