I have a component that is a table. Each row of this table is also component.
    class FormulaBuilder extends Component {
        constructor(props) {
            super(props);
            this.state = {
                rows: [{}]
            }
        }
handleAddRow = () => {
        const item = {};
        this.setState({
            rows: [...this.state.rows, item]
        });
    };
    handleRemoveSpecificRow = (idx) => {
        const rows = [...this.state.rows]
        rows.splice(idx, 1)
        this.setState({ rows })
    }
     render() {
            return (
               {
                   this.state.rows.map((item, idx) => {
                        return (
                           <React.Fragment key={idx}>
                                 <ConcoctionRow
                                  removeSpecificRow={(idx) =>this.handleRemoveSpecificRow(idx)}
                                  id={idx} />
                            </React.Fragment>);
                })
             });
            }
    }
In the child component there is a button. When clicked, the event from the parent component is called:
class ConcoctionRow extends Component {
    constructor(props) {
        super(props);
    }
  handleRemoveSpecificRow = () => {
        this.props.removeSpecificRow(this.props.id);
    }
}
The properties passed the index of the array. But only the last line is always deleted not specific.
Where is my bad? P.S. I am new in JS.
 
     
    