JS中將字符串中每個單詞的首字母大寫化


今天看到一個帖子,處理js中字符串每個單詞的首字母大寫。

原貼地址:關於字符串中每個單詞的首字母大寫化問題

受到啟發,自己跟着改寫了幾個版本如下,請大家指正。

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

思路:用正則將每個單詞的首字母替換成大寫。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM