1. 程式人生 > >JS中將字串中每個單詞的首字母大寫化

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