1、for循环实现之
vara='Hi, my name\'s Han Meimei, a SOFTWARE engineer';//for循环functiontitleCase(s){vari,ss=s.toLowerCase().split(/\s+/);for(i=0;i<ss.length;i++){ss[i]=ss[i].slice(0,1).toUpperCase()+ss[i].slice(1);}returnss.join(' ');}console.log(titleCase(a));这个逻辑应该说非常常见。
2、for循环+replace:
//for循环+replacefunctiontitleCase1(str){//将字符串分解为数组并将其小写化varconvertToArray=str.toLowerCase().split(" ");for(vari=0;i<convertToArray.length;i++){varchar=convertToArray[i].charAt(0);//使用 replace()方法将数组中的每个首字母大写化convertToArray[i]=convertToArray[i].replace(char,functionreplace(char){returnchar.toUpperCase();});}returnconvertToArray.join(" ");}console.log(titleCase1(a));这个跟第一个差别不大。
3、正则+replace:
//正则+replacefunctiontitleCase2(s){returns.toLowerCase().replace(/\b([\w|']+)\b/g,function(word){//return word.slice(0, 1).toUpperCase() + word.slice(1);returnword.replace(word.charAt(0),word.charAt(0).toUpperCase());});}console.log(titleCase2(a));思路:用正则将字符串拆分为单词数组,并对每个单词进行首字母大写处理。这里简单的把字母、数字、下划线和单撇号都视为了单词成员。
4、数组+map:
//数组+mapfunctiontitleCase3(s){returns.toLowerCase().split(/\s+/).map(function(item,index){returnitem.slice(0,1).toUpperCase()+item.slice(1);}).join(' ');}console.log(titleCase3(a));思路:根据空白将字符串拆分为数组,对每个单词进行首字母大写处理,并将所有处理后的结果组成一个新数组然后拼接成字符串。
5、数组+reduce
//数组+reducefunctiontitleCase4(s){returns.toLowerCase().split(/\s+/).reduce(function(prev,item,array,array){returnprev+(prev.trim()&&' ')+item.slice(0,1).toUpperCase()+item.slice(1);},'');}console.log(titleCase4(a));思路:根据空白将字符串拆分为数组,对每个单词进行首字母大写处理,并将所有处理后的结果连成一个新字符串。
6、ES6写法
//ES6写法functiontitleCase5(str){returnstr.toLowerCase().replace(/( |^)[a-z]/g,(L)=>L.toUpperCase());}console.log(titleCase5(a));思路:用正则将每个单词的首字母替换成大写。