6

可能重复:
在 jquery 中查找数组的长度(大小)

我有一个从 php 文件返回的 json 对象,如下所示:-

{"food":[
    {
        "name"       :"Belgian Waffles",
        "price"      :"$5.95",
        "description":"two of our famous Belgian Waffles with plenty of real maple syrup",
        "calories"   :"650"
    },
    {
        "name"       :"Strawberry Belgian Waffles",
        "price"      :"$7.95",
        "description":"light Belgian waffles covered with strawberries and whipped cream",
        "calories"   :"900"
    },
    {
        "name"       :"Berry-Berry Belgian Waffles",
        "price"      :"$8.95",
        "description":"light Belgian waffles covered with an assortment of fresh berries and whipped cream",
        "calories"   :"900"
    }
]}

这实质上是从对象返回三个食物元素。如果 json 数据是动态的并且使用 jquery 未知,我如何计算返回的元素总数?

4

3 回答 3

16

假设您已经解析了 JSON(或者 jQuery 已经为您完成了解析,如果您使用它的 Ajax 函数,它将解析)并且您将结果对象放在变量中,只需执行以下操作:

var data = /* your parsed JSON here */
var numberOfElements = data.food.length;

(注意:没有 JSON 对象之类的东西:在解析 JSON 之前它是一个字符串;解析它之后它是一个对象。

编辑:在评论中您说您不知道该属性被调用food- 如果您确实知道将有一个属性并且该属性将是一个数组,您可以这样做:

var data = /* your object */
var propName;
var numberOfElements;
for (propName in data);
numberOfElements = propName ? data[propName].length : 0;

如果您知道只有一个属性,那么您的要求就太模糊了:如果可能有多个属性,您要检查哪一个的长度?

于 2012-12-17T00:59:04.340 回答
6
var json = '{"food":[{"name":"Belgian Waffles","price":"$5.95","description":"two of our famous Belgian Waffles with plenty of real maple syrup","calories":"650"},{"name":"Strawberry Belgian Waffles","price":"$7.95","description":"light Belgian waffles covered with strawberries and whipped cream","calories":"900"},{"name":"Berry-Berry Belgian Waffles","price":"$8.95","description":"light Belgian waffles covered with an assortment of fresh berries and whipped cream","calories":"900"}]}';

var obj = JSON.parse(json);

alert(obj.food.length);​

演示:http: //jsfiddle.net/XhG6L/

请注意,IE8 及以下版本不支持 JSON,但有可用的 polyfill。

另外,作为另一个说明,jQuery 在这里没有做这项工作——这只是普通的旧 javascript。

于 2012-12-17T00:59:19.790 回答
0

如果 json 数据是动态的并且使用 jquery 未知,我如何计算返回的元素总数?

您可以使用长度属性来获取计数。应在食品项目上调用此属性。由于 food 返回了三个项目,您可以使用data.food.length; data 是全局对象。

还要确保您的JSON 是有效的。虽然它似乎有效,但看起来有手动换行符,在这种情况下它将失败:

于 2012-12-17T01:12:52.770 回答