30 lines
1.2 KiB
Markdown
30 lines
1.2 KiB
Markdown
---
|
|
title: Truncate string at whitespace
|
|
tags: string
|
|
cover: blog_images/cloudy-mountaintop-2.jpg
|
|
firstSeen: 2020-10-19T11:11:16+03:00
|
|
lastUpdated: 2020-10-21T21:17:45+03:00
|
|
---
|
|
|
|
Truncates a string up to specified length, respecting whitespace when possible.
|
|
|
|
- Determine if `String.prototype.length` is greater or equal to `lim`. If not, return it as-is.
|
|
- Use `String.prototype.slice()` and `String.prototype.lastIndexOf()` to find the index of the last space below the desired `lim`.
|
|
- Use `String.prototype.slice()` to appropriately truncate `str` based on `lastSpace`, respecting whitespace if possible and appending `ending` at the end.
|
|
- Omit the third argument, `ending`, to use the default ending of `'...'`.
|
|
|
|
```js
|
|
const truncateStringAtWhitespace = (str, lim, ending = '...') => {
|
|
if (str.length <= lim) return str;
|
|
const lastSpace = str.slice(0, lim - ending.length + 1).lastIndexOf(' ');
|
|
return str.slice(0, lastSpace > 0 ? lastSpace : lim - ending.length) + ending;
|
|
};
|
|
```
|
|
|
|
```js
|
|
truncateStringAtWhitespace('short', 10); // 'short'
|
|
truncateStringAtWhitespace('not so short', 10); // 'not so...'
|
|
truncateStringAtWhitespace('trying a thing', 10); // 'trying...'
|
|
truncateStringAtWhitespace('javascripting', 10); // 'javascr...'
|
|
```
|