Я следую учебному пособию по React / Redux и из нескольких статей в Интернете я понял, что встроенные функции плохо влияют на производительность в React.
Из того, что я понял, функции являются ссылочным типом, и если вы используете встроенную функцию, для каждого повторного рендеринга эта функция будет занимать другое место в памяти.
В учебном примере у меня есть метод deleteExperience (), который инструктор использовал встроенным.
import React, { Fragment } from 'react';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import Moment from 'react-moment';
import { Link, withRouter } from 'react-router-dom';
import { deleteExperience } from '../../actions/profileActions';
const Experience = ({ experience, deleteExperience }) => {
const experiences = experience.map(exp => (
<tr key={exp._id}>
<td>{exp.company}</td>
<td className="hide-sm">{exp.title}</td>
<td>
<Moment format="YYYY/MM/DD">{exp.from}</Moment> -
{exp.to === null ? (
' Now '
) : (
<Moment format="YYYY/MM/DD">{exp.to}</Moment>
)}
</td>
<td>
<button className="btn btn-danger" onClick={() => deleteExperience(exp._id)}>
Delete
</button>
</td>
</tr>
));
return (
<Fragment>
<h2 className="my-2">Experience Credentials</h2>
<table className="table">
<thead>
<tr>
<th>Company</th>
<th className="hide-sm">Title</th>
<th className="hide-sm">Years</th>
<th />
</tr>
</thead>
<tbody>{experiences}</tbody>
</table>
</Fragment>
);
};
Experience.propTypes = {
experience: PropTypes.array.isRequired,
deleteExperience: PropTypes.func
};
export default connect(
null,
{deleteExperience}
)(withRouter(Experience));
Итак, инструктор сказал, что он использовал встроенную функцию
onClick={() => deleteExperience(exp._id)}
а не просто вызываемая напрямую функция
onClick={deleteExperience(exp._id)}
не подлежит немедленному исполнению.
Итак, пожалуйста, кто-нибудь, скажите мне, если теория о плохой практике использования встроенных функций верна, как справиться с этой ситуацией? Я пробовал много способов, но безуспешно.