0.0.3 • Published 8 years ago
@importvault/bindall v0.0.3
bindall ( ob , fns , selected )
API
ob- Object to bind methods to.fns- is an object whose values get fixed bound toob
optional
selected- Array of string providing names of selected functions to bind - in case when binding needs to be done selectively.
Install
npm install @importvault/bindallInternals
reassign
.thisto fixed object for selected functionsmutates
fnsthat holds the functionsOther implementation ( lodash, underscore ) of
bindalldoes not provide option to control whatfnsis bound to.40 lines of code.
Examples
. . binding all functions in object
| livescript |
|---|
var bindall = require("@importvault/bindall")
var log = function()
{
console.log(this);
}
var ob =
{
fuel:"coffee",
fns:
{
foo:log
}
}
ob.fns.foo() // { foo: [Function: foo] } // cannot access .fuel :(
bindall(ob,ob.fns) // will mutate original object
ob.fns.foo()
// { fuel: 'coffee', fns: { foo: [Function] } } // can access .fuel now !. . for applying to a subset number of functions
| livescript |
|---|
var bindall = require("@importvault/bindall")
var log = function()
{
console.log(this);
}
ob =
{
fuel:"coffee",
fns:
{
foo:log,
bar:log
}
}
bindall(ob , ob.fns , ["bar"])
ob.fns.bar()
// { fuel: 'coffee', fns: { log: [Function] , bar: [Function] }}
ob.fns.foo()
// { fns: { log: [Function] , bar: [Function] } } License
Code and document released under MIT Licence, see LICENSE file.
0.0.3
8 years ago