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.
		
		
		
		
		
			
		
			
				
					44 lines
				
				1.2 KiB
			
		
		
			
		
	
	
					44 lines
				
				1.2 KiB
			| 
											3 years ago
										 | var root = require('./_root'), | ||
|  |     toString = require('./toString'); | ||
|  | 
 | ||
|  | /** Used to match leading whitespace. */ | ||
|  | var reTrimStart = /^\s+/; | ||
|  | 
 | ||
|  | /* Built-in method references for those with the same name as other `lodash` methods. */ | ||
|  | var nativeParseInt = root.parseInt; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Converts `string` to an integer of the specified radix. If `radix` is | ||
|  |  * `undefined` or `0`, a `radix` of `10` is used unless `value` is a | ||
|  |  * hexadecimal, in which case a `radix` of `16` is used. | ||
|  |  * | ||
|  |  * **Note:** This method aligns with the | ||
|  |  * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.
 | ||
|  |  * | ||
|  |  * @static | ||
|  |  * @memberOf _ | ||
|  |  * @since 1.1.0 | ||
|  |  * @category String | ||
|  |  * @param {string} string The string to convert. | ||
|  |  * @param {number} [radix=10] The radix to interpret `value` by. | ||
|  |  * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. | ||
|  |  * @returns {number} Returns the converted integer. | ||
|  |  * @example | ||
|  |  * | ||
|  |  * _.parseInt('08'); | ||
|  |  * // => 8
 | ||
|  |  * | ||
|  |  * _.map(['6', '08', '10'], _.parseInt); | ||
|  |  * // => [6, 8, 10]
 | ||
|  |  */ | ||
|  | function parseInt(string, radix, guard) { | ||
|  |   if (guard || radix == null) { | ||
|  |     radix = 0; | ||
|  |   } else if (radix) { | ||
|  |     radix = +radix; | ||
|  |   } | ||
|  |   return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0); | ||
|  | } | ||
|  | 
 | ||
|  | module.exports = parseInt; |