JS:如何大写字符串中每个符号分隔的单词的首字母?

问题描述 投票:2回答:4

当字符串有一个单词时,我的JS很好:

  • 布鲁诺==>布鲁诺

当字符串是空格时,它也能正常工作:

  • JEAN MARC ==> Jean Marc

但是当我得到一个下划线的单词时? :

  • JEAN-FRANCOIS ==>让 - 弗朗索瓦(错)

我的目的是概括它来实现:

  • JEAN-FRANCOIS ==> Jean-Francois

我如何让它变得像那样?

我的脚本是这样的:

capitalizeString(str) {
    var lowerString = str.toLowerCase();
    return lowerString.replace(/(^| )(\w)/g, (x) => {
      return x.toUpperCase();
    });
}
javascript regex typescript ecmascript-6 ecmascript-5
4个回答
1
投票

您可以添加连字符(-)作为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'));

1
投票

如果您要使用多个分隔符,可以使用它们创建一个数组,并使用它来动态创建正则表达式。像这样:

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));

0
投票

您可以将每个首字母以及每个字母后面的大写字母大写:

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"));

0
投票

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
© www.soinside.com 2019 - 2024. All rights reserved.