For a quiz, I am playing with Pangrams, sentences that have all 26 letters of the alphabet in them. Using Set and some RegEx it is a one-liner in JavaScript to validate them (split into two lines for readability…).
const isPangram = s => new Set(
s.toLowerCase().replace(/[^a-z]/g, '')
).size === 26;
I've also put together a small tool for myself to write pangrams and check them whilst I type. You can see it in action here:
data:image/s3,"s3://crabby-images/19246/19246f031ba9d42dda4d90add534bef709d9a967" alt="screen recording of the tool validating a sentence"
Do you have a shorter solution?
Top comments (2)
.match(/[a-z]/g)
instead of.replace(/[^a-z]/g, '').split('')
match()
just return an array of matching strings.TIL the word Pangram and I had fun playing with the tool. 🙏🏼💗