绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
JavaScript实现单词首字母大写的方法总汇
2022-01-05 15:06:07



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 = ; i < ss.length; i++) {          ss[i] = ss[i].slice(, 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 = ; i < convertToArray.length; i++) {          var char = convertToArray[i].charAt();          //使用 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(, 1).toUpperCase() + word.slice(1);          return word.replace(word.charAt(), word.charAt().toUpperCase());      });  }  console.log(titleCase2(a));

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

4、数组+map:

//数组+map  function titleCase3(s) {      return s.toLowerCase().split(/\s+/).map(function(item, index) {          return item.slice(, 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(, 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));

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

本文完~

分享好友

分享这个小栈给你的朋友们,一起进步吧。

Java小专栏
创建时间:2019-08-08 21:32:06
Java专栏专注技术分享
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

栈主、嘉宾

查看更多
  • lihong
    栈主

小栈成员

查看更多
  • 栈栈
  • 杨三百
  • at_1
  • gaokeke123
戳我,来吐槽~