您的位置:首页 > 其它

将字符串的首位换成大写其余小写。

2017-11-23 11:25 260 查看
1、for循环:

[javascript] view
plain copy

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:

[javascript] view
plain copy

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

这个跟第一个差别不大。

3、正则+replace:

[javascript] view
plain copy

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

[javascript] view
plain copy

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

[javascript] view
plain copy

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

[javascript] view
plain copy

//ES6写法  

function titleCase5(str) {  

    return str.toLowerCase().replace(/( |^)[a-z]/g, (L) => L.toUpperCase());  

}  

console.log(titleCase5(a));  

思路:用正则将每个单词的首字母替换成大写。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐