Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rakannimer/deref-mobx-observable
Dereference mobx observables deep in your component tree.
https://github.com/rakannimer/deref-mobx-observable
Last synced: 12 days ago
JSON representation
Dereference mobx observables deep in your component tree.
- Host: GitHub
- URL: https://github.com/rakannimer/deref-mobx-observable
- Owner: rakannimer
- Created: 2018-09-30T12:14:23.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-09-30T12:32:32.000Z (over 6 years ago)
- Last Synced: 2025-01-18T00:42:13.238Z (about 1 month ago)
- Language: TypeScript
- Size: 470 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# deref-mobx-observable
[![BundlePhobia][bundlephobia-badge]][bundlephobia-href]
> Deref mobx observables deep in your component directory for better performance.
[data:image/s3,"s3://crabby-images/92eb2/92eb2780d84d92bf4f9da1b75b82b1e7a37f1ae0" alt="NPM"](https://www.npmjs.com/package/deref-mobx-observable) [data:image/s3,"s3://crabby-images/432d6/432d695915e1b608030587a7ba48baa6280c643d" alt="JavaScript Style Guide"](https://standardjs.com)
[data:image/s3,"s3://crabby-images/12cdc/12cdc60d89d802716329b86734581bb2b17f470d" alt="Build Status"](https://travis-ci.org/rakannimer/deref-mobx-observable)
## Install
```bash
yarn add deref-mobx-observable # Or npm install --save deref-mobx-observable
```## Usage
```tsx
import * as React from "react";
import { observable } from "mobx";
import Deref from "deref-mobx-observable";
const val = observable.box(1);export default class App extends React.Component<{ Deref: typeof Deref }> {
static defaultProps = {
Deref
};
render() {
const { Deref } = this.props;
return (
👇 won't be re-rendered
{Date.now()}
{value => (
// This will be re-rendered
👇 will be re-rendered
{Date.now()}
{JSON.stringify(value)}
)}
👇 won't be re-rendered
{
val.set(val.get() + 1);
}}
data-testid="change"
>
Increment
{Date.now()}
);
}
}
```## License
MIT © [rakannimer](https://github.com/rakannimer)
[bundlephobia-badge]: https://img.shields.io/bundlephobia/minzip/deref-mobx-observable.svg
[bundlephobia-href]: https://bundlephobia.com/result?p=deref-mobx-observable