当字符串有一个单词时,我的JS很好:
当字符串是空格时,它也能正常工作:
但是当我得到一个下划线的单词时? :
我的目的是概括它来实现:
我如何让它变得像那样?
我的脚本是这样的:
capitalizeString(str) {
var lowerString = str.toLowerCase();
return lowerString.replace(/(^| )(\w)/g, (x) => {
return x.toUpperCase();
});
}
您可以添加连字符(-
)作为RegEx的一部分:
function capitalizeString(str) {
var lowerString = str.toLowerCase();
return lowerString.replace(/(^|[ -])(\w)/g, (x) => {
return x.toUpperCase();
});
}
console.log(capitalizeString('BRUNO'));
console.log(capitalizeString('JEAN MARC'));
console.log(capitalizeString('JEAN-FRANCOIS'));
如果您要使用多个分隔符,可以使用它们创建一个数组,并使用它来动态创建正则表达式。像这样:
const separators = ['^', ' ', '-'];
const capitalizeString = (str) =>
str.toLowerCase()
.replace(new RegExp(`(${separators.join('|')})\\w`, 'g'), (x) => x.toUpperCase());
const s1 = 'BRUNO';
const s2 = 'JEAN MARC';
const s3 = 'JEAN-MARC';
console.log(capitalizeString(s1));
console.log(capitalizeString(s2));
console.log(capitalizeString(s3));
您可以将每个首字母以及每个字母后面的大写字母大写:
function capitalizeString(str) {
var lowerString = str.toLowerCase();
return lowerString.replace(new RegExp("(?:\\b|_)([a-z])", "g"), (x) => {
return x.toUpperCase();
});
}
console.log(capitalizeString("abcd-efgh"));
String.prototype.capitalized = function () {
return this.toLowerCase().replace(/(^|[^a-z])[a-z]/g, v => v.toUpperCase());
};
console.log('I-love-YOU-guy'.capitalized()); // => I-Love-You-Guy