2016-03-28 170 views
0

我有一個JSON包含以下數據,當我在JavaScript中處理它時,我想通過每個元素,如果它是NULL,然後刪除它,如果它是一個數組我想循環通過子數組,並找到它裏面的任何空元素並刪除。我嘗試了下面的代碼,但是它無法識別一個元素是否是數組內的一個數組。檢查一個數組中的元素是否爲數組或不在javascript/jquery

CODE:

  for (var key in data) { 

       if (!data[key]) { 
        delete data[key]; 
       }else if(data.key && data.key.constructor === Array){ 
         var subArray = data[key]; 
         for(var subKey in subArray){ 
          if (!data[key]) 
          delete subArray[subKey]; 
        } 
       } 

      } 

JSON:

{ 
    confirmDate : "2016-03-27T23:24:36.338Z", 
    earliestPossibleInhandDate : "2016-03-28T23:24:36.338Z", 
    eventStartTime : null, 
    lastChanceDate : null, 
    latestPossibleInhandDate : null, 
    metas : Array[1], 
    onSaleDate : "2016-03-28T23:24:41.461Z" 
    primaryCategoryId : "114", 
    secondaryGroupings : Array[2], 
    status : "active" 
} 

編輯:改性JSON

{ 
    "secondaryGroupings": [{ 
     "groupingId": "720072", 
     "status": "active" 
    }, { 
     "groupingId": null, 
     "status": null 
    }], 
    "secondaryPerformers": [{ 
     "status": null 
    }], 
    "metas": [{}], 
    "status": "active", 
    "primaryCategoryId": "7667", 
    "eventStartTime": null, 
    "lastChanceDate": null, 
    "onSaleDate": "2016-03-29T00:25:56.670Z", 
    "confirmDate": "2016-03-28T00:25:56.670Z", 
    "earliestPossibleInhandDate": "2016-03-29T00:25:56.670Z", 
    "latestPossibleInhandDate": null 
} 
+0

與那個JSON有什麼關係?你有沒有嘗試驗證它?我沒有看到任何逗號和數組語法是錯誤的。 http://jsonlint.com/ –

+0

它只是一個示例JSON,我已經從Chrome控制檯複製:) – user1614862

+0

有點必須給我們有效的JSON,如果你想解析JSON的任何真正的幫助,只是說... – MattSizzle

回答

0
for (var key in data) { 
    // you are deleting all the null values 
    if (!data[key]) { 
     delete data[key]; 
    } 
    // here key is a variable so you must access key as data[key] with bracket notation 
    // also the first check here is a bit redundant as you already deleted the null values 
    else if(data.key && data.key.constructor === Array){ 
      var subArray = data[key]; 
      // you can go over arrays like this but it is better to do a normal for loop or use Array.prototype.forEach because an array is not a key value store 
      for(var subKey in subArray){ 
       if (!data[key]) 
       delete subArray[subKey]; 
     } 
    } 
} 

// something like this.. 
for (var key in data) { 
    if (!data[key]) { 
     delete data[key]; 
    } 
    if (data[key].constructor === Array){ 
     var subArray = data[key]; 
     subArray.forEach(function(item) { 
     // I am not sure what your inner array looks like is it an array of objects? 
      // do stuff with each item 
     }) 
    } 
} 

// this works for your dataset but it ain't pretty 
function stripData(data) { 
    if (Array.isArray(data)){ 
    data.forEach(function(item) { 
     stripData(item); 
    }) 
    return data.filter(function(item) { 
     return Object.keys(item).length > 0; 
    }) 
    } else if (typeof data === 'object') { 
    for (key in data) { 
     if (data[key] === null || data[key].length === 0) delete data[key]; 
     else data[key] = stripData(data[key]); 
    } 
    return data; 
    } 
    for (key in data) { 
    if (data[key].length === 0) delete data[key] 
    } 
    return data; 
} 

data = stripData(stripData(data)) 
+0

我的內部數組只有簡單的值。如果我的內部數組中的所有元素都由於NULL而被刪除,那麼我想從主JSON對象中移除內部數組本身。 – user1614862

+0

你可以舉一個內部數組的例子嗎? – joemillervi

+0

在我的問題的編輯部分提供了完整的JSON。在那裏,我想從secondaryGroupings中刪除一個帶有空值的條目,並刪除secondaryPerformer本身,因爲它具有所有空條目並刪除已經爲空的元數組。 – user1614862

0
function removeNull(obj,key){ 
    var thisIsNull=false; 
    if(key==null||key==undefined){ 
     if(isJson(obj)){ 

      for(var i in obj){ 
       thisIsNull=removeNull(obj,i); 
      } 
     } 
    }else if(key !=null){ 
     if(isJson(obj[key])){ 
      var jsonIsNull=true; 
      for(var i in obj[key]){ 
       if(obj[key][i]!=null){ 
        jsonIsNull=false; 
       } 
       thisIsNull=removeNull(obj[key],i); 
      } 
      if(jsonIsNull){ 
       delete obj[key]; 

       thisIsNull=true;    } 
     }else if(obj[key]==null){ 
      delete obj[key]; 
     }else if(obj[key] instanceof Array){ 
      var arrIsNull=true; 
      for(var i in obj[key]){ 
       if(obj[key][i]!=null){ 
        arrIsNull=false; 
        thisIsNull=removeNull(obj[key],i); 
       }else{ 
        delete obj[key][i]; 
       } 
      } 
      if(arrIsNull){ 
       thisIsNull=true; 
       delete obj[key]; 
       thisIsNull=removeNull(obj); 
      } 
     } 


    } 
    if(thisIsNull){ 
     removeNull(obj); 
    } 
    return thisIsNull; 

} 

function isJson(obj){ 
    var isjson = typeof(obj) == "object" && Object.prototype.toString.call(obj).toLowerCase() == "[object object]" && !obj.length; 
    return isjson; 
} 
+0

removeNull(jsonObj); –

0
function deleteNulls(json) { 
    for (var key in json) { 
     if (Array.isArray(json[key])) { 
      json[key].forEach(function (Obj, index, Array) { 
       for (var property in Obj) { 
        if (Obj[property] == null) { 
         Array.splice(index, 1); 
        } 
       } 
      }); 
     } 
     if (json[key] == null || json[key].length == 0) {  
      delete json[key]; 
     } 
    } 
} 

deleteNulls(myObject); 
相關問題