简体   繁体   中英

How to build an array from a jSon object

I am trying to build 2 arrays from JSON arrays.

{
    "2015-03-24": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "150",
        "promo": "",
        "status": "available"
    },
    "2015-03-25": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "150",
        "promo": "",
        "status": "available"
    },
    "2015-03-26": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "150",
        "promo": "",
        "status": "available"
    },
    "2015-03-27": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "100",
        "promo": "",
        "status": "available"
    },
    "2015-03-28": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "100",
        "promo": "",
        "status": "available"
    },
    "2015-03-29": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "100",
        "promo": "",
        "status": "available"
    },


    "2015-04-10": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "",
        "promo": "",
        "status": "booked"
    },
    "2015-04-11": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "",
        "promo": "",
        "status": "booked"
    },

    "2015-05-01": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "",
        "promo": "",
        "status": "unavailable"
    },
    "2015-05-02": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "",
        "promo": "",
        "status": "unavailable"
    },
    "2015-05-03": {
        "bind": 0,
        "info": "",
        "notes": "",
        "price": "",
        "promo": "",
        "status": "unavailable"
    },


}

This is the jSon array, so I want to build 2 arrays.

1 array holding only keys (in this case the date) of those element where status=='booked' nOR status=='unavailable' and build it in jQuery array like this

var array = ['2015-03-19', '2015-03-20', '2015-03-21', '2015-03-22', '2015-03-23', '2015-03-24', '2015-03-25', '2015-03-26', '2015-04-07', '2015-04-08', '2015-04-09', '2015-04-10'];

Another is building another array with the dates of those days where status=='available' AND price > '100$'

var array2 = [ '2015-03-25', '2015-03-26', '2015-04-07', '2015-04-08'];

How can I achieve this on with jQuery?

If j is your json:

var a1 = [];
var a2 = [];
$.each( j, function( key, ob ) {
    if(ob.price > 100 && ob.status == 'available'){
        a1.push(key);
    }
    if(ob.status == 'booked' || ob.status == 'unavailable'){
        a2.push(key);
    }
});
console.log(a1);
console.log(a2);

Yields:

["2015-03-24", "2015-03-25", "2015-03-26"]
["2015-04-10", "2015-04-11", "2015-05-01", "2015-05-02", "2015-05-03"]

You could have a more generic approach, that could be useful to adapt in other scenarios of yours, without dependencies from jQuery. A small function for data filtering:

function from(data) {
  var predicates = [];
  var results = [];

  function exec() {
    for (var k in data) {
      if (data.hasOwnProperty(k)) {
        for (var i = 0, l = predicates.length; i < l; i++) {
          if (predicates[i](data[k])) {
            results[i][k] = data[k]
          }
        }
      }
    }

    return results;
  }

  exec.get = function(predicate) {
    predicates.push(predicate);
    results.push({});
    return exec;
  }

  return exec;
}

Giving that, you can now write code like:

// predicates
function isNotAvailable(item) {
  return item.status === "unavailable" || item.status === "booked"
}

function isAvailableAndPriceGreater100(item) {
  return item.status === "available" && +item.price > 100
}

// results
var results = from(obj)
               .get(isNotAvailable)
               .get(isAvailableAndPriceGreater100)
               ();

Where obj is your object with all the data.

That command will returns two array, one for each predicate defined, with all the object – because it could be useful if you want to access to some properties, o filter again. If you want only the keys, at that point you can simply do:

var notAvailableDates = Object.keys(results[0]);

Try this,

var array1 = [];
var array2 = [];
$.each(data.items, function(key, val) {
   if((val.status == 'booked') || (val.status == 'unavailable')){
     array1.push(key);
   }
   if((val.status == 'available') && (val.price > 100)){
     array2.push(key);
   }
})
function obj_key_select(obj, func) {
    newArr = [];
    for(var index in obj) { 
        if (obj.hasOwnProperty(index)) {
            if(func(obj[index])) {
                newArr.push(index);
            }
        }
    }
    return newArr;
}

var dates = JSON.parse(jsonString);

var arrOne = obj_key_select(dates, function(element){
    return (element.status === 'booked' || element.status === 'unavailable'); 
});

var arrTwo = obj_key_select(dates, function(element){
    return (element.status === 'available' && parseInt(element.price) > 100); 
});

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM