@DaniilRuss

Как передать родительский метод в дочерний?

Надо чтобы при нажатии на
<CloseOutlined onClick={props.handleDelete}  key="delete" />, ]}>

Удалялась карточка на которую я нажал

Не судите строго, я просто только начинаю изучать react
Вот весь код
import React, { Component } from 'react'
import { Card, message } from 'antd';
import { CloseOutlined } from '@ant-design/icons';

const CardInfo = (props) => { 

	return(
		<Card {...props} style={{ width: 300, marginTop: 16, marginRight: 20 }} actions={[
			<CloseOutlined onClick={props.handleDelete}  key="delete" />, ]}>
			<h3>Заказ № {props.id}</h3>
			<div className="orders__info">
				<span>Имя: {props.name}</span>
				<span>Телефон: {props.phone}</span>
				<span>Тип объекта: {props.type}</span>
				<span>Состояние: {props.objstate}</span>
				<span>Площадь: {props.area}</span>
				<span>Дизайн-проект: {props.disign}</span>
				<span>Полы: {props.floor}</span>
				<span>Стены: {props.wall}</span>
				<span>Потолки: {props.ceiling}</span>
				<span>Цена: {props.price}</span>
			</div>
		</Card>
  );
}

const CardStructure = (props) => {

	return (
		<CardInfo {...props}/>	
	);
}

const CardList = (props) => {
	return (
    	<div className="cards__list">
        {props.cards.map(card => <CardStructure {...card} />)}
      </div>
    );
};

export default class Orders extends Component {
	constructor(props) {
		super(props)
	
		this.state = {
			 data: [
				{
					key: 1,
					id: 1,
					name: 'Данил',
					phone: '88005553535',
					type: 'Квартира',
					objstate: 'Стройвариант',
					area: 220,
					disign: 1,
					floor : 'плитка',
					wall: 'Обои',
					ceiling: 'Гипсокартон',
					price: 240000
				},
				{
					key: 2,
					id: 2,
					name: 'Вася',
					phone: '89666666666',
					type: 'Дом',
					objstate: 'Стройвариант',
					area: 550,
					disign: 2,
					floor : 'Ламинат',
					wall: 'Обои',
					ceiling: 'Гипсокартон',
					price: 1000000
				}
			 ]
		}
	}
	
	handleDelete(key) {
		const data = [...this.state.data];
		this.setState({ data: data.filter(item => item.key !== key) });
		message.warning('Заказ удален');
	}

	render() {
		return (
			<div className="orders">
				<h2>Заказы</h2>
				<CardList handleDelete={this.handleDelete} cards={this.state.data}/>
			</div>
		)
	}
}
  • Вопрос задан
  • 66 просмотров
Решения вопроса 1
0xD34F
@0xD34F Куратор тега React
handleDelete = e => {
  const id = +e.currentTarget.dataset.id;
  this.setState(({ data }) => ({
    data: data.filter(n => n.id !== id),
  }));
}

const CardList = ({ cards, handleDelete }) => (
  <div className="cards__list">
    {cards.map(n => <CardInfo {...n} handleDelete={handleDelete} />)}
  </div>
);

<CloseOutlined onClick={props.handleDelete} data-id={props.id} />
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
@dimoff66
Кратко о себе: Я есть
В этом месте в компоненте CardList обрывается передача handler-а

{props.cards.map(card => <CardStructure {...card} />)}


Нужно в CarfStructure передать handler из props
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы