Задать вопрос
  • Как добавить несколько элементов в массив под одним id?

    @szzlep Автор вопроса
    лучше наверно так: где я тут накосячил?
    должно сохраняться "input" как заголовок и "textarea" как текст

    class App extends React.Component {
        constructor() {
            super();
            this.state = {items: [], value: '', value1: ''};
        }
    
        handleChange(event) {
            this.setState({value: event.target.value});
        }
        handleChange1(event) {
            this.setState({value1: event.target.value});
        }
    
        //Добавляем в конец списка новый пункт:
        addItem(event) {
            this.setState({
                value: '',
                value1: '',
            })
            //Добавляем новый элемент в массив:
            this.state.items.push(this.state.value, this.state.value1);
    
            //Применяем изменение:
            this.setState({items: this.state.items});
    
            //Отменяем отправку формы:
            event.preventDefault();
        }
    
    
        render() {
    
            const list = this.state.items.map(( index, item, item1) =>
                <Box key={index} value={item}>{item1}</Box>
            );
            return (
                <div>
                    <form>
                        <input
                            value={this.state.value} name='value'
                            onChange={this.handleChange.bind(this)}
                        />
                        <input
                            value={this.state.value1} name='value1'
                            onChange={this.handleChange1.bind(this)}
                        />
                        <button onClick={this.addItem.bind(this)}>Add</button>
                    </form>
                    <div>
                        {list}
                    </div>
                </div>
            );
        }
    
    
    const Box = (props) => {
        const {title, text} = props;
        return(
            <div className='box'>
                <h1>{title}</h1>
                <p>{text}</p>
            </div>
        )
    }