0.1.4 • Published 9 years ago

class-autobind v0.1.4

Weekly downloads
34,686
License
ISC
Repository
github
Last release
9 years ago

Method auto-bind for ES6 (ES2015) classes

This package provides a single function, autobind, for use within a constructor to bind all methods to the instance itself.

For example, this allows us to pass a method to an event handler element.addEventListener('click', this.onClick) and be sure the onClick method will always be called with the right context.

Note: This has some specific logic for React, but could be used in any project.

Usage:

import autobind from 'class-autobind';

class MyComponent extends React.Component {
  constructor() {
    super(...arguments);
    autobind(this);
  }
  render() {
    return <button onClick={this.onClick}>Click Me</button>;
  }
  onClick() {
    console.log('Button Clicked');
  }
}

Advanced Usage:

If your component will possibly be subclassed (you really should not do this, but some third-party libraries like react-css-modules do so) then you will need to specify which prototype will be the source of methods that are to be automatically bound.

import autobind from 'class-autobind';

class MyComponent extends React.Component {
  constructor() {
    super(...arguments);
    autobind(this, MyComponent.prototype); // Note the second parameter.
  }
  render() {
    /* ... */
  }
}

class MySubClassedComponent extends MyComponent {
  /* This is probably a very bad idea. */
}

License

This software is BSD Licensed.

react-img-carousel-x@idkman/gold-material-tablereact-rte-i18n@everything-registry/sub-chunk-1332swift-react-rtevisual-testing@dock365/react-rte@cosmology/cli@cosmology/corejx-react-rte@psychwire/react-rtesshttpsur41-react-rtetimecamp-v2-javascript-clienttrespass-visualizations@agolo/output-config-rte@4nduril/react-rte@ikonintegration/react-rte@davidsackett/react-rte@graphql-guru/ide@happens-lol/react-rte@humanz/react-rte@matthewberryman/react-rte@occmundial/occ-atomicmtarapata-react-rtemuse-rtemeteor-compounder-corern-zoomablereact-band-walletreact-alex-rteroy-gbiv_react-rteqbl-react-rtesemantic-ui-react-rtereact-draft-rtereact-fetch-loadingreact-native-qiscus-sdkreact-otpnode-bits-internal-databasenode-bits-passwordnode-bits-restreact-richtextreact-recurly-modalshengnian-editorreact-stripe-modalreact-rtereact-rte-17react-rte-18supportreact-rte-browserifyreact-rte-browserify-imagereact-rte-es5react-rte-gcreact-rte-scoped-stylereact-rte-semanticreact-rte-with-cloudinaryreact-rte-ytreact-rte2react-rte-imagereact-rte-imagesupportreact-rte-link-extendedreact-rte-marked-unsafereact-rte-materialreact-rte-mentionreact-rte-modifiedreact-rte-qbreact-rte-ref-fixgillespie59-react-rtegraphql-guru-jsondbgraphql-guru-mongodbgraphql-guru-redisgraphql-guru-rethinkdbgraphql-guru-sequelizehtml-verify-react-rtehf-react-rteinterwebjsless.jsmaterial-ui-form-helpersll-react-rte@trojanowski/react-rte@zalastax/nolb-clasandersryanc--react-rteaejis-react-rtebuzhuo-k8s-uicl-react-rtecw-print-servicecw-printer-servicedealroom-react-rteband-walletdexmosdraft-rtedraftjs-evandds-react-rteelm-react-reduxfetch-hoc-reduxgeta-checkout
0.1.4

9 years ago

0.1.3

9 years ago

0.1.2

9 years ago

0.1.1

9 years ago

0.1.0

9 years ago