JavaScript实现单词首字母大写的方法集锦

Posted tea_year

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript实现单词首字母大写的方法集锦相关的知识,希望对你有一定的参考价值。

1、for循环实现之

var a = 'Hi, my name\\'s Han Meimei, a SOFTWARE engineer';  
  
//for循环  
function titleCase(s)   
    var i, ss = s.toLowerCase().split(/\\s+/);  
    for (i = 0; i < ss.length; i++)   
        ss[i] = ss[i].slice(0, 1).toUpperCase() + ss[i].slice(1);  
      
    return ss.join(' ');  
  
console.log(titleCase(a));

这个逻辑应该说非常常见。
2、for循环+replace:

//for循环+replace  
function titleCase1(str)   
    //将字符串分解为数组并将其小写化  
    var convertToArray = str.toLowerCase().split(" ");  
  
    for (var i = 0; i < convertToArray.length; i++)   
        var char = convertToArray[i].charAt(0);  
        //使用 replace()方法将数组中的每个首字母大写化  
        convertToArray[i] = convertToArray[i].replace(char, function replace(char)   
            return char.toUpperCase();  
        );  
      
    return convertToArray.join(" ");  
  
console.log(titleCase1(a));

这个跟第一个差别不大。

3、正则+replace:


//正则+replace  
function titleCase2(s)   
    return s.toLowerCase().replace(/\\b([\\w|']+)\\b/g, function(word)   
        //return word.slice(0, 1).toUpperCase() + word.slice(1);  
        return word.replace(word.charAt(0), word.charAt(0).toUpperCase());  
    );  
  
console.log(titleCase2(a));

思路:用正则将字符串拆分为单词数组,并对每个单词进行首字母大写处理。这里简单的把字母、数字、下划线和单撇号都视为了单词成员。

4、数组+map:

//数组+map  
function titleCase3(s)   
    return s.toLowerCase().split(/\\s+/).map(function(item, index)   
        return item.slice(0, 1).toUpperCase() + item.slice(1);  
    ).join(' ');  
  
console.log(titleCase3(a));

思路:根据空白将字符串拆分为数组,对每个单词进行首字母大写处理,并将所有处理后的结果组成一个新数组然后拼接成字符串。

5、数组+reduce

//数组+reduce  
function titleCase4(s)   
    return s.toLowerCase().split(/\\s+/).reduce(function(prev, item, array, array)   
        return prev + (prev.trim() && ' ') + item.slice(0, 1).toUpperCase() + item.slice(1);  
    , '');  
  
console.log(titleCase4(a));

思路:根据空白将字符串拆分为数组,对每个单词进行首字母大写处理,并将所有处理后的结果连成一个新字符串。

6、ES6写法

//ES6写法  
function titleCase5(str)   
    return str.toLowerCase().replace(/( |^)[a-z]/g, (L) => L.toUpperCase());  
  
console.log(titleCase5(a));

思路:用正则将每个单词的首字母替换成大写。

以上是关于JavaScript实现单词首字母大写的方法集锦的主要内容,如果未能解决你的问题,请参考以下文章

我看书JavaScript将每个单词首字母变大写

python方法和函数集锦

如何使用 JavaScript 将字符串中每个单词的首字母大写?

javascript 将单词首字母大写,其余小写

css实现将英文语句第一个单词首字母大写

仅第一个单词的大写首字母[重复]