- Published on
How to correctly split a string into words in JavaScript
Or why you should stop using the split function!
- Authors
- Name
- Nico Prananta
- Follow me on Bluesky
If you have been using .split(' ')
to get an array of words from a string, you should stop doing so. It works perfectly for English, but it's not the best solution for other languages.
For example, if you have a string like this:
const str = '俺はルフィ!海賊王になる男だ!'
console.table(str.split(' '))
you will get this:
Image
data:image/s3,"s3://crabby-images/42637/4263787aa26468559c0ae30a8d7ccf1de8bdbd78" alt=""
which is not what we want. That's the whole sentence.
Instead, we should use the Intl.Segmenter!
const str = '俺はルフィ!海賊王になる男だ!'
const segmenterJa = new Intl.Segmenter('ja-JP', { granularity: 'word' })
const segments = segmenterJa.segment(str)
console.table(Array.from(segments))
Image
data:image/s3,"s3://crabby-images/d058d/d058d9743a625d64398d365cc49440262d38397d" alt=""
We can also use { granularity: 'sentence' }
to get the sentences in the string.
Image
data:image/s3,"s3://crabby-images/6b7c3/6b7c3ed10014f7db260854c7d6789cbebf34fd16" alt=""
By the way, I'm making a book about Pull Requests Best Practices. Check it out!