14

我正在尝试编写一个函数,例如转换list-style-imagelistStyleImage.

我想出了一个功能,但它似乎不起作用。谁能指出我这里的问题?

var myStr = "list-style-image";

function camelize(str){
    var newStr = "";    
    var newArr = [];
    if(str.indexOf("-") != -1){
        newArr = str.split("-");
        for(var i = 1 ; i < newArr.length ; i++){
            newArr[i].charAt(0).toUpperCase();
        }       
        newStr = newArr.join("");
    }
    return newStr;
}

console.log(camelize(myStr));
4

16 回答 16

22

您必须实际重新分配数组元素:

    for(var i = 1 ; i < newArr.length ; i++){
        newArr[i] = newArr[i].charAt(0).toUpperCase();
    }       

“toUpperCase()”函数返回新字符串但不修改原始字符串。

您可能需要先检查以确保它newArr[i]是空字符串,以防您得到一个带有两个连续破折号的输入字符串。

编辑— 著名的 SO 贡献者 @lonesomeday 正确地指出,您还需要将每个字符串的其余部分粘回去:

         newArr[i] = newArr[i].charAt(0).toUpperCase() + newArr[i].substr(1);
于 2011-10-12T16:51:17.840 回答
7

这是我使用 ES6 的解决方案。这是一个示例,我将星期几存储在数组中,并用for... of循环将它们大写。

const days = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'];

for (let day of days) {
    day = day.charAt(0).toUpperCase() + day.substr(1);
    console.log(day);
}

这是文档的链接:for... of loop documentation

于 2017-12-29T21:03:56.247 回答
6

在您的for循环中,您需要替换值newArr[i]而不是简单地评估它:

for(var i = 1 ; i < newArr.length ; i++){
    newArr[i] = newArr[i].charAt(0).toUpperCase() + newArr[i].substr(1);
}
于 2011-10-12T16:52:32.263 回答
6
const days = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'];

days.map( a => a.charAt(0).toUpperCase() + a.substr(1) );
于 2018-07-11T19:40:41.247 回答
3

从 JavaScript ES6 开始,您可以用一行代码实现字符串数组的“骆驼化”:

let newArrCamel= newArr.map(item=> item.charAt(0).toUpperCase() + item.substr(1).toLowerCase())
于 2018-12-17T21:37:39.977 回答
2

您不需要数组将连字符和小写字母替换为大写 -

function camelCase(s){
    var rx=  /\-([a-z])/g;
    if(s=== s.toUpperCase()) s= s.toLowerCase();
    return s.replace(rx, function(a, b){
        return b.toUpperCase();
    });
}

camelCase("list-style-image")

/*  returned value: (String)
listStyleImage
*/
于 2011-10-12T16:58:37.740 回答
2

您需要将大写字母存储回数组中。请参考下面的修改循环,

for(var i = 1 ; i < newArr.length ; i++)
{
    newArr[i] = newArr[i].charAt(0).toUpperCase() + newArr[i].substr(1,newArr[i].length-1);
}
于 2011-10-12T16:59:44.113 回答
2

稍微长一点,但它基本上完成了使用数组的工作:

function titleCase(str) {
  var arr = [];
  var arr2 = [];
  var strLower = "";
  var strLower2 = "";
  var i;
  arr = str.split(' ');

  for (i=0; i < arr.length; i++) {

    arr[i] = arr[i].toLowerCase();
    strLower = arr[i];
    arr2 = strLower.split('');
    arr2[0] = arr2[0].toUpperCase();
    strLower2 = arr2.join('');
    arr[i] = strLower2;
  }

  str = arr.join(' ');

  return str;
}

titleCase("I'm a little tea pot");
于 2016-01-21T12:54:06.127 回答
2

substr()方法返回起始索引和它之后的多个字符之间的字符串部分。来源:https ://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/substr

const days = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'];
for (let day of days) {
  day = day.substr(0, 1).toUpperCase() + day.substr(1);
  console.log(day);
}

于 2018-05-17T10:55:31.423 回答
1

尽管我在游戏中这么晚了,但这是另一个解决方案。

const days = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'];

let capitalize = days.map(day => day.charAt(0).toUpperCase() + day.slice(1).toLowerCase());

console.log(capitalize);

于 2019-08-28T08:54:11.167 回答
0
function titleCase(str){    // my codelooks like Jmorazano but i only use 4 var.
var array1 = [];
var array2 = []; 
var array3 = "";
var i;
array1 = str.split(" ");
for (i=0; i < array1.length; i++) {
array1[i]= array1[i].toLowerCase();
array2=array1[i].split("");
array2[0]=array2[0].toUpperCase();
array3 = array2.join("");
array1[i] = array3;}

str = array1.join(' ');
return str;}
titleCase("I AM WhO i aM"); //Output:I Am Who I Am
// my 1st post.
于 2017-06-15T03:50:24.733 回答
0

这就是我将如何去做。

function capitalizeFirst(arr) {
  if (arr.length === 1) {
    return [arr[0].toUpperCase()];
  }
  let newArr = [];
  for (let val of arr) {
    let value = val.split("");
    let newVal = [value[0].toUpperCase(), ...value.slice(1)];
    newArr.push(newVal.join(""));
  }
  return newArr;
}
于 2019-12-02T13:29:40.203 回答
0

让我们检查下面的代码。

['sun','mon'].reduce((a,e)=> { a.push(e.charAt(0).toUpperCase()+e.substr(1)); return a; },[]);

输出: [“太阳”,“星期一”]

于 2020-01-16T06:42:40.760 回答
0

请检查下面的代码

 var months = ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'november', 'decembar'];

for(let month of months){
    month = month.charAt(0).toUpperCase() + month.substr(1);
    console.log(month);
}
于 2021-04-17T17:05:19.040 回答
0

这是我使用 slice() 方法的解决方案。

const names = ["alice", "bob", "charlie", "danielle"]

const capitalized = names.map((name) => {
    return name[0].toUpperCase() + name.slice(1)

})

console.log(大写)

// 预期输出: // ["Alice", "Bob", "Charlie", "Danielle"]

于 2021-12-31T20:48:30.173 回答
0

我最好的方法是:

function camelCase(arr) {
  let calc = arr.map(e => e.charAt(0).toUpperCase() + e.slice(1)).join('')
  console.log(calc)
  return calc;
}

// Test
camelCase(['Test', 'Case'])

于 2022-02-10T19:10:26.880 回答