• JavaScript实现单词首字母大写的方法总汇


    JavaScript实现单词首字母大写的方法总汇

    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));
    这个逻辑应该说非常常见。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    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
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    这个跟第一个差别不大。

    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));
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

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

    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));
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    思路:根据空白将字符串拆分为数组,对每个单词进行首字母大写处理,并将所有处理后的结果组成一个新数组然后拼接成字符串。

    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));
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    思路:根据空白将字符串拆分为数组,对每个单词进行首字母大写处理,并将所有处理后的结果连成一个新字符串。

    6、ES6写法

    //ES6写法  
    function titleCase5(str) {  
        return str.toLowerCase().replace(/( |^)[a-z]/g, (L) => L.toUpperCase());  
    }  
    console.log(titleCase5(a));
    
    • 1
    • 2
    • 3
    • 4
    • 5

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

    - End -

    *陆荣涛前端学习交流Q群858752519
    加群备注:CSDN推荐

    请添加图片描述

  • 相关阅读:
    关闭二维码
    动态内存精讲
    postman:Tests模块之断言
    抖音矩阵系统,抖音矩阵系统,抖音矩阵系统,抖音矩阵系统,抖音矩阵系统,抖音矩阵系统,抖音矩阵系统,抖音矩阵系统。
    【正点原子I.MX6U-MINI应用篇】9、嵌入式Linux中的多线程编程pthread
    日料西餐厅餐品预约小程序的作用是什么
    优彩云采集器下载-免费优彩云采集器下载地址
    太空射击第13课: 爆炸效果
    Ubuntu系统下创建虚拟AP和STA扫描/关联/认证/ping
    7_spring-cloud-config-center
  • 原文地址:https://blog.csdn.net/sdasadasds/article/details/125403973