2016-10-10 03:43:44 +02:00
|
|
|
var baseClamp = require('./_baseClamp'),
|
|
|
|
baseToString = require('./_baseToString'),
|
|
|
|
toInteger = require('./toInteger'),
|
|
|
|
toString = require('./toString');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if `string` starts with the given target string.
|
|
|
|
*
|
|
|
|
* @static
|
|
|
|
* @memberOf _
|
|
|
|
* @since 3.0.0
|
|
|
|
* @category String
|
|
|
|
* @param {string} [string=''] The string to inspect.
|
|
|
|
* @param {string} [target] The string to search for.
|
|
|
|
* @param {number} [position=0] The position to search from.
|
|
|
|
* @returns {boolean} Returns `true` if `string` starts with `target`,
|
|
|
|
* else `false`.
|
|
|
|
* @example
|
|
|
|
*
|
|
|
|
* _.startsWith('abc', 'a');
|
|
|
|
* // => true
|
|
|
|
*
|
|
|
|
* _.startsWith('abc', 'b');
|
|
|
|
* // => false
|
|
|
|
*
|
|
|
|
* _.startsWith('abc', 'b', 1);
|
|
|
|
* // => true
|
|
|
|
*/
|
|
|
|
function startsWith(string, target, position) {
|
|
|
|
string = toString(string);
|
2017-04-20 03:09:25 +02:00
|
|
|
position = position == null
|
|
|
|
? 0
|
|
|
|
: baseClamp(toInteger(position), 0, string.length);
|
|
|
|
|
2016-10-10 03:43:44 +02:00
|
|
|
target = baseToString(target);
|
|
|
|
return string.slice(position, position + target.length) == target;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = startsWith;
|