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));
1與2寫法差別不大
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));
思路:用正則將每個單詞的首字母替換成大寫。