69 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 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;
 |