You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
2.0 KiB
68 lines
2.0 KiB
var baseRest = require('./_baseRest'), |
|
createWrap = require('./_createWrap'), |
|
getHolder = require('./_getHolder'), |
|
replaceHolders = require('./_replaceHolders'); |
|
|
|
/** Used to compose bitmasks for function metadata. */ |
|
var WRAP_BIND_FLAG = 1, |
|
WRAP_BIND_KEY_FLAG = 2, |
|
WRAP_PARTIAL_FLAG = 32; |
|
|
|
/** |
|
* Creates a function that invokes the method at `object[key]` with `partials` |
|
* prepended to the arguments it receives. |
|
* |
|
* This method differs from `_.bind` by allowing bound functions to reference |
|
* methods that may be redefined or don't yet exist. See |
|
* [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern) |
|
* for more details. |
|
* |
|
* The `_.bindKey.placeholder` value, which defaults to `_` in monolithic |
|
* builds, may be used as a placeholder for partially applied arguments. |
|
* |
|
* @static |
|
* @memberOf _ |
|
* @since 0.10.0 |
|
* @category Function |
|
* @param {Object} object The object to invoke the method on. |
|
* @param {string} key The key of the method. |
|
* @param {...*} [partials] The arguments to be partially applied. |
|
* @returns {Function} Returns the new bound function. |
|
* @example |
|
* |
|
* var object = { |
|
* 'user': 'fred', |
|
* 'greet': function(greeting, punctuation) { |
|
* return greeting + ' ' + this.user + punctuation; |
|
* } |
|
* }; |
|
* |
|
* var bound = _.bindKey(object, 'greet', 'hi'); |
|
* bound('!'); |
|
* // => 'hi fred!' |
|
* |
|
* object.greet = function(greeting, punctuation) { |
|
* return greeting + 'ya ' + this.user + punctuation; |
|
* }; |
|
* |
|
* bound('!'); |
|
* // => 'hiya fred!' |
|
* |
|
* // Bound with placeholders. |
|
* var bound = _.bindKey(object, 'greet', _, '!'); |
|
* bound('hi'); |
|
* // => 'hiya fred!' |
|
*/ |
|
var bindKey = baseRest(function(object, key, partials) { |
|
var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG; |
|
if (partials.length) { |
|
var holders = replaceHolders(partials, getHolder(bindKey)); |
|
bitmask |= WRAP_PARTIAL_FLAG; |
|
} |
|
return createWrap(key, bitmask, object, partials, holders); |
|
}); |
|
|
|
// Assign default placeholders. |
|
bindKey.placeholder = {}; |
|
|
|
module.exports = bindKey;
|
|
|