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.
		
		
		
		
		
			
		
			
				
					69 lines
				
				2.0 KiB
			
		
		
			
		
	
	
					69 lines
				
				2.0 KiB
			| 
											3 years ago
										 | 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; |