JavaScript算法练习:关于字符串中每个单词的首字母大写化问题著作权归作者所有。 商业转载请联系作者获得授权,非商业转载请注明出处。 原文: https://www.w3cplus.com/javascript/title-case-a-sentence-in-javascript.html?utm_source=tuicool&utm_medium=referral © w3cplus.c

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

 

posted @ 2019-04-02 15:26  zqgq312  阅读(351)  评论(0编辑  收藏  举报