trimEnd.js 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. import baseToString from './_baseToString.js';
  2. import castSlice from './_castSlice.js';
  3. import charsEndIndex from './_charsEndIndex.js';
  4. import stringToArray from './_stringToArray.js';
  5. import toString from './toString.js';
  6. import trimmedEndIndex from './_trimmedEndIndex.js';
  7. /**
  8. * Removes trailing whitespace or specified characters from `string`.
  9. *
  10. * @static
  11. * @memberOf _
  12. * @since 4.0.0
  13. * @category String
  14. * @param {string} [string=''] The string to trim.
  15. * @param {string} [chars=whitespace] The characters to trim.
  16. * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
  17. * @returns {string} Returns the trimmed string.
  18. * @example
  19. *
  20. * _.trimEnd(' abc ');
  21. * // => ' abc'
  22. *
  23. * _.trimEnd('-_-abc-_-', '_-');
  24. * // => '-_-abc'
  25. */
  26. function trimEnd(string, chars, guard) {
  27. string = toString(string);
  28. if (string && (guard || chars === undefined)) {
  29. return string.slice(0, trimmedEndIndex(string) + 1);
  30. }
  31. if (!string || !(chars = baseToString(chars))) {
  32. return string;
  33. }
  34. var strSymbols = stringToArray(string),
  35. end = charsEndIndex(strSymbols, stringToArray(chars)) + 1;
  36. return castSlice(strSymbols, 0, end).join('');
  37. }
  38. export default trimEnd;