连接字符串的正确方法是什么?

时间:2012-05-03 13:51:31

标签: javascript json

var d=getEntity( {"Division": 
{
"oddTerms": 
    [           
        {
              "entity": "Sunshine",
              "Sunshine": [
                    {
                         "count": 2,
                        "entity": "Dodge"
                    },
                    {
                        "count": 1,
                        "entity": "Dodge Avenger"
                    },

              ]
        }
  ]

}});

我想遍历json字符串,实体名称为Dodge和Dodge Avenger。我使用了以下方法

for (var k in h.Division.oddTerms)
{
s=h.Division.oddTerms[k].entity;
h.Division.oddTerms[k].+s+.entity;
}

但我认为这不是正确的连接方法,因为它不是wrking ..谁知道正确的格式?

2 个答案:

答案 0 :(得分:1)

oddTerms是一个数组,而不是一个对象。对于JavaScript中的数组,您需要使用带有计数器的for循环,而不是迭代元素:

var concatedString = '';
for (var k=0; k<h.Division.oddTerms.length;k++)
{
    // Get the name of the entity we want to collect the entity terms of
    var entityName =h.Division.oddTerms[k].entity;
    // iterate through all the instances of each entity
    for(var j=0; j<h.Division.oddTerms[k][entityName].length;j++){
      concatedString += h.Division.oddTerms[k][entityName][j].entity;
    }
}

答案 1 :(得分:0)

var entityName = "",
    arrTerms = [],
    outputTemplate = '{"%entityName":[%terms]}',
    h = {
        "Division":
        {
            "oddTerms":
            [
                {
                    "entity": "Sunshine",
                    "Sunshine": [
                    {
                        "count": 2,
                        "entity": "Dodge"
                    },
                    {
                        "count": 1,
                        "entity": "Dodge Avenger"
                    },

                    ]
                }
            ]

        }
    };

for (var i = 0; i <  h.Division.oddTerms.length; i++)
{
    entityName=h.Division.oddTerms[i].entity; // "Sunshine"
    terms = h.Division.oddTerms[i][entityName];

    for (var j = 0; j < terms.length; j++) {
        arrTerms.push('"' + terms[j].entity + '"');
    }
}

// This will give you '{"Sunshine":["Dodge","Dodge Avenger"]}':
console.log(outputTemplate.replace('%entityName', entityName).replace('%terms', arrTerms.join(",")));

编辑:

还有更多内容。

如果你不习惯使用JS和对象和数组“文字”,那么使用JSON可能会有点混乱。在JS中,您可以通过多种方式定义对象和数组,但最简单的(也是最受欢迎的,许多开发人员)都使用这些文字。

以下是对象的示例:

var myObj = {
    "some prop":"some value",
    "anotherProp":"another value"
}

您可以通过多种方式查找myObj的成员:

myObj.anotherProp //“另一个值”

myObj["some prop"] //如果属性名称中有空格,则必须使用此表单

要循环遍历数组的内容,请使用第二种形式。例如,这不起作用:

for (var strPropName in myObj) {
   console.log(myObj.strPropName); // This won't work!
}

相反,你应该循环遍历这样的属性:

for (var strPropName in myObj) {
    if (myObj.hasOwnProperty(strPropName)) {
       console.log(myObj[strPropName]);
    }
}

if块是可选的,但如果您始终在代码中包含此问题,则可以避免潜在的问题。某些验证人员也要求它。

现在,这是一个数组示例:

var myArray = ["some value", "anotherValue"];

您可以使用数字索引访问这些:

myArray[0] // "some value"
myArray[1] // "anotherValue"
myArray[2] // undefined

你可以循环使用它们:

for (var index = 0; index < myArray.length; index++) {
    console.log(myArray[index]);
}

您可以将对象嵌套在数组中:

myArray = [{},{},{}];

您可以在对象中嵌套数组:

myObject = {"arr1":[], "arr2":[], "arr3":[]}