Security News
ESLint is Now Language-Agnostic: Linting JSON, Markdown, and Beyond
ESLint has added JSON and Markdown linting support with new officially-supported plugins, expanding its versatility beyond JavaScript.
babel-plugin-react-persist
Advanced tools
A Babel plug-in that optimizes your React components' implementation by automatically detecting declarations that should persist between rendering phases and replacing them with useCallback()
and useMemo()
whenever necessary. This plug-in can also be used with inline anonymous functions in JSX attributes and solve excessive processing power issues. Note that this plug-in is experimental and shouldn't be used in production yet. Compatible with React 16.7 and above (hooks support).
export default ({
data,
sortComparator,
filterPredicate,
history,
}) => {
const transformedData = data
.filter(filterPredicate)
.sort(sortComparator)
return (
<div>
<button className="back-btn" onClick={() => history.pop()} />
<ul className="data-list">
{transformedData.map(({ id, value }) => (
<li className="data-item" key={id} onClick={() => history.push(`data/${id}`)}>{value}</li>
))}
</ul>
</div>
)
}
export default (({
data,
sortComparator,
filterPredicate,
history,
}) => {
const transformedData = React.useMemo(() =>
data
.filter(filterPredicate)
.sort(sortComparator)
, [data, filterPredicate, sortComparator])
const _onClick = React.useCallback(() =>
history.pop()
, [history])
return (
<div>
<button className="back-btn" onClick={_onClick} />
<ul className="data-list">
{transformedData.map(({ id, value }) => {
const _onClick2 = React.useCallback(() =>
history.push(`data/${id}`)
, [history, id])
return (
<li className="data-item" key={id} onClick={_onClick2}>{value}</li>
)
})}
</ul>
</div>
)
})
babel-plugin-react-persist
is installable via NPM (or Yarn):
$ npm install babel-plugin-react-persist
Add to .babelrc
under plugins
and be sure to load it before any JSX transformation related plug-ins.
{
"presets": ["@babel/preset-react"],
"plugins": ["babel-plugin-react-persist"]
}
MIT. If you're including this in a repo above 1k stars I would really appreciate it if you could contact me first.
FAQs
Automatically useCallback() and useMemo()
The npm package babel-plugin-react-persist receives a total of 12 weekly downloads. As such, babel-plugin-react-persist popularity was classified as not popular.
We found that babel-plugin-react-persist demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
ESLint has added JSON and Markdown linting support with new officially-supported plugins, expanding its versatility beyond JavaScript.
Security News
Members Hub is conducting large-scale campaigns to artificially boost Discord server metrics, undermining community trust and platform integrity.
Security News
NIST has failed to meet its self-imposed deadline of clearing the NVD's backlog by the end of the fiscal year. Meanwhile, CVE's awaiting analysis have increased by 33% since June.