'Javascript method to capitalize the first letter of every word and also every word after hyphen or dash
I need a JavaScript method to allows me to convert the first letter of every word in a string to a capital letter like this: mike tyson wayne
to Mike Tyson Wayne
.
The method should also be able to convert the first word after an hyphen to capital letter like this: mike-tyson wayne
to Mike Tyson Wayne
.
The method should also be able to convert uppercase words to capitalize words like this: MIKE-TYSON WAYNE
to Mike Tyson Wayne
.
I have tried this method using regular expression gotten from another thread:
text.replace(/(^\w{1})|(\s{1}\w{1})/g, match => match.toUpperCase())
- (^\w{1}): match first char of string
- |: or
- (\s{1}\w{1}): match one char that came after one space
- g: match all
- match => match.toUpperCase(): replace with can take function, so; replace match with upper case match
It worked for converting the first letter of a string to capital letter and also works for the first letter of a string after space.
I added this expression that was supposed to cater for first letter of a string after space to the expression. The expression is (?:- |\d\. ).*
Combined with the first expression, it became:
text.replace(/(^\w{1})|(\s{1}\w{1})|(?:- |\d\. ).*/g, match => match.toUpperCase());
The problem is that the method above doesn't work for the strings after the dash but still works for the strings after space.
Solution 1:[1]
\d
is a digit, so your expression matches a-
or a digit followed by.
...{1}
means one occurrence, which is the default anyways...
Try something like this:
/(^\w)|([-\s]\w)/g
Solution 2:[2]
A regex like ... /(?<=\b)\w/g
or /(?<=\b)\p{L}/gu
... which both use a positive lookbehind for word boundaries but the second variant making use of Unicode property escapes might be a more generic yet viable approach ...
console.log(
"mike-tyson wayne"
.replace((/(?<=\b)\w/g), match => match.toUpperCase())
);
console.log(
"MIKE-TYSON WAYNE"
.toLowerCase()
.replace((/(?<=\b)\p{L}/gu), match => match.toUpperCase())
);
.as-console-wrapper { min-height: 100%!important; top: 0; }
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
Solution | Source |
---|---|
Solution 1 | Usagi Miyamoto |
Solution 2 |