JS中的字符串修改问题

时间:2012-07-12 17:49:19

标签: javascript jquery

我有一个类似" word_count"的字符串。如何将其转换为" WordCount"以优雅的方式使用JavaScript?我的决定似乎太复杂了。我非常感谢你的帮助。

10 个答案:

答案 0 :(得分:7)

function titleCase(str)
{
    return str.split("_")
        .map(function (s) { return s.charAt(0).toUpperCase() + s.slice(1); })
        .join("");
}

答案 1 :(得分:4)

看看this。我不想在这里复制粘贴所有东西,但它似乎正是你正在寻找的东西。

以下是根据您的要求修改的功能:

String.prototype.toCamel = function(){
    return this.replace(/((^|\_)[a-z])/g, function($1){
                return $1.toUpperCase().replace('_','');});
};

here它正在行动中。

答案 2 :(得分:3)

您可以使用正则表达式匹配字符串开头的字母或下划线后面的字母,并使用回调将字母转换为大写:

s = s.replace(/(?:^|_)([a-z])/g, function(m, g){
  return g.toUpperCase();
});

演示:http://jsfiddle.net/Guffa/ByU6P/

答案 3 :(得分:2)

简单,像这样:

var string = "word_count".split("_");
for(var i = 0; i<string.length;i++) {
    string[i] = string[i].charAt(0).toUpperCase() + string[i].substr(1);
}
var myNiceString = string.join();

如果要将其添加到String对象,可以执行以下操作:

String.prototype.titleCase = function() {
    var split = this.split("_");
    for(var i = 0; i<split.length;i++) {
        split[i] = split[i].charAt(0).toUpperCase() + split[i].substr(1);
    }
    return split.join("");
}

您可以将其称为"word_count".titleCase();

答案 4 :(得分:1)

您可以使用以下功能:

var Pascalize = function(word) {
    var x = word;
    result = '';
    if(-1 != word.indexOf('_')) {
        x = word.split('_');
        for(var i=0;i<x.length;i++) {
            result += x[i].substr(0, 1).toUpperCase() + x[i].substr(1);
        }
    }
    if('' == result) { result = word; }
    return result;
};

var PascalCaseString = Pascalize("this_is_a_test");
// PascalCaseString value is now 'ThisIsATest'

Here's a working example

答案 5 :(得分:0)

var str = "word_count";
var re = /\b(.)([^_]+)_(.)/;
var newWord = str.replace(re, function(m,f,t,l){ return f.toUpperCase() + t + l.toUpperCase();})
console.log(newWord);

答案 6 :(得分:0)

使用jQuery,您可以执行以下操作:

var result = '';
$.each('word_count'.split('_'), function(idx,elem){
  result = result + elem.substr(0,1).toUpperCase() + elem.substr(1);
});

答案 7 :(得分:0)

新版本(适用于任何数量的_):

function fixString(sString) {

    var aWords = sString.split("_"),
        sResults = "";

    for (var i in aWords)
        sResults += aWords[i].charAt(0).toUpperCase() + aWords[i].slice(1);

    return sResults;

}

压缩形式:

function fixString(c){var d=c.split("_"),a="";for(var b in d){a+=d[b].charAt(0).toUpperCase()+d[b].slice(1)}return a};

旧:

function fixString(sString) {

    return sString.replace(/(.*)_(.*)/, function(sWhole, $1, $2, sWTF) {

        return ucfirst($1) + ucfirst($2);

    } )

    function ucfirst (str) {

        str += '';

        var f = str.charAt(0).toUpperCase();

        return f + str.substr(1);

    }

}

...或压缩版本:

function fixString(b){return b.replace(/(.*)_(.*)/,function(e,c,f,d){return a(c)+a(f)});function a(d){d+="";var c=d.charAt(0).toUpperCase();return c+d.substr(1)}};

当然,这与fixString("word_count")类似,会产生您想要的WordCount

答案 8 :(得分:0)

我看了所有的答案,没有一个人完全按照我的意愿行事。我想要一个转换为camelCase(而不是PascalCase)的幂等函数,我喜欢String原型扩展方法(尽管显然这并不是最好的药)。

无论如何,我最终在这里:

String.prototype.camelize = function(){
    var pascalCase = this.replace(/((^|\_)[a-z])/g, function($1){
        return $1.toUpperCase().replace('_','');
    });
    return pascalCase.charAt(0).toLowerCase() + this.slice(1);
};

答案 9 :(得分:-1)

var aStringLike = "word_count";

// magic follows

aStringLike = "WordCount";