Files
lodash/trim.js
2017-02-07 17:55:40 -08:00

46 lines
1.3 KiB
JavaScript

import baseToString from './.internal/baseToString.js'
import castSlice from './.internal/castSlice.js'
import charsEndIndex from './.internal/charsEndIndex.js'
import charsStartIndex from './.internal/charsStartIndex.js'
import stringToArray from './.internal/stringToArray.js'
import toString from './toString.js'
/**
* Removes leading and trailing whitespace or specified characters from `string`.
*
* @since 3.0.0
* @category String
* @param {string} [string=''] The string to trim.
* @param {string} [chars=whitespace] The characters to trim.
* @param- {Object} [guard] Enables use as an iteratee for methods like `map`.
* @returns {string} Returns the trimmed string.
* @see trimEnd, trimStart
* @example
*
* trim(' abc ')
* // => 'abc'
*
* trim('-_-abc-_-', '_-')
* // => 'abc'
*
* map([' foo ', ' bar '], trim)
* // => ['foo', 'bar']
*/
function trim(string, chars, guard) {
string = toString(string)
if (string && (guard || chars === undefined)) {
return string.trim()
}
if (!string || !(chars = baseToString(chars))) {
return string
}
const strSymbols = stringToArray(string)
const chrSymbols = stringToArray(chars)
const start = charsStartIndex(strSymbols, chrSymbols)
const end = charsEndIndex(strSymbols, chrSymbols) + 1
return castSlice(strSymbols, start, end).join('')
}
export default trim