JS字符串首字母都大写的几种方法

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

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

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


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_6475