Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/steamerjs/pure-render-immutable-decorator

适配immutable的react pure-render-decorator
https://github.com/steamerjs/pure-render-immutable-decorator

Last synced: about 1 month ago
JSON representation

适配immutable的react pure-render-decorator

Awesome Lists containing this project

README

        

## pure-render-immutable-decorator

compare props and state automatically

### Install

```
$ npm install pure-render-immutable-decorator --save
```

### Usage

If you don't care the data in `shouldComponentUpdate`, you can just use the decorator way. But you have to install `babel-plugin-transform-decorators-legacy` plugin for compilation.

```js
import pureRender from "pure-render-immutable-decorator";

@pureRender
class List extends Component {
constructor(props, context) {
super(props, context);
}

render() {

return (


);
}
}

```

If you need to modify logic in `shouldComponentUpdate`, you can use it like this:

```js
import { deepCompare } from "pure-render-immutable-decorator";

class List extends Component {
constructor(props, context) {
super(props, context);
}

shouldComponentUpdate(nextProps, nextState) {

// some logic

var shouldUpdate = /* some logic */

return deepCompare(this, nextProps, nextState) && shouldUpdate;

}

render() {

return (


);
}
}

```

### Non-Immutable Version
* [pure-render-deepCompare-decorator](https://github.com/SteamerTeam/pure-render-deepCompare-decorator)