js截取字符串方法_web前端入门到实战: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循环+replacefunction 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

//正则+replacefunction 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

//数组+mapfunction 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

//数组+reducefunction 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));web前端开发学习Q-q-u-n:600610151,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(从零基础开始到前端项目实战教程,学习工具,职业规划 )

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

25338a2954daff9121ca2332a0984e67.png


作者:大前端世界
链接:https://www.jianshu.com/p/19184280d67b

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值