Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

react-with-stable

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-with-stable

React withStable HOC

  • 0.1.3
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

react-with-stable

npm npm bundle size npm type definitions GitHub

This package provides stable identity inline callbacks when passing props.

Please ⭐ star this repo if it's useful!

TL;DR

import { withStable } from "react-with-stable";

const Event = withStable(["onClick"], ({ onClick }) => (
  <button onClick={onClick}>click</button>
));

export default function App() {
  const [text, setText] = React.useState("a");

  return (
    <div>
      <input value={text} onChange={(e) => setText(e.target.value)} />
      <Event onClick={() => alert(`click: ${text}`)}/>
    </div>
  );
}

No matter how text state changes, the Event component never re-renders because onClick is declared as a stable prop.
But when onClick fires as an event handler, it will get latest text value.

Note: don't use onClick in effects or rendering.

Demo

Please check this codesandbox example. It proves that the withStable wrapped components never re-render unless other non-stable props change.

Explanation

This package basically does the same thing as useEventHandler like many community implementaion and useEvent RFC the React team is working on. The difference is that it wraps callbacks in HOC, so it can provide stable identity for inline callback where hook methods can't achieve it.

You have to explicitly provide stable prop keys in the first parameter of withStable like withStable(["onClick"],. This is actually better in concept in most scenario because it should be the callback consumer (i.e. Event component) to know this prop (onClick) is stable and only used in events.

This package doesn't solve the old values in closure problem in effects, so I believe useEvent RFC should still be essential.

Keywords

FAQs

Package last updated on 27 May 2022

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc