§ Quick Take

import { strict as assert } from "assert";
import { strIndexesOfPlus } from "str-indexes-of-plus";

// searches for string in a string, returns array:
  strIndexesOfPlus("abc-abc-abc-abc", "abc"),
  [0, 4, 8, 12]

// all graphemes are counted as one, emoji too:
  strIndexesOfPlus("🐴-🦄", "🦄"),
  [2] // not [3] considering unicorn is 2-characters long

// you can offset the start of a search:
  strIndexesOfPlus("abczabc", "abc", 3),

§ Compared to Others

method / programreturnsindex system based on
String.prototype.indexOf() opens in a new tabindex where the first finding startscode point count
str-indexes-of opens in a new tabarray of indexes where each finding startscode point count
📦 This package,
array of indexes where each finding startsgrapheme count

See this opens in a new tab article about Unicode, graphemes and code points.



In other words, it's a function which takes three arguments, third one is optional (marked by square brackets).

Output: an array of zero or more numbers, each indicating the index of each finding's first character. Unicode astral characters are counted, as one character-long.

Input argumentTypeObligatory?Description
strstringyesSource string, where to search.
searchValuestringyesWhat to search for.
fromIndexnatural number or zeronoIf set, the searching will start from this index.

§ Trivia

Roy asked ~Shinnn opens in a new tab is it all right to create grapheme-count-based-index alternative of his str-indexes-of opens in a new tab and he said it's OK.

§ Changelog

See it in the monorepo opens in a new tab, on GitHub.

§ Contributing

To report bugs or request features or assistance, raise an issue on GitHub opens in a new tab.

Any code contributions welcome! All Pull Requests will be dealt promptly.

§ Licence

MIT opens in a new tab

Copyright © 2010–2021 Roy Revelt and other contributors

Related packages:

📦 str-indexes-of opens in a new tab
Like String#indexOf() but return all indexes
📦 edit-package-json 0.3.14
Edit package.json without parsing, as string, to keep the formatting intact
📦 easy-replace 4.0.14
Replace strings with optional lookarounds, but without regexes
📦 email-all-chars-within-ascii 3.0.14
Scans all characters within a string and checks are they within ASCII range
📦 js-row-num 4.0.14
Update all row numbers in all console.logs in JS code
📦 line-column-mini 1.1.14
Convert string index to line-column position
📦 string-split-by-whitespace 2.0.14
Split string into array by chunks of whitespace