1

I am getting array like below.

[{},
 {},
 {},
{ label: '2015', showLabels: '1,' },
 {},
 {},
 {},
{ label: ‘2017’, showLabels: '1,' }]

but, I would like to delete empty indexes.

I have tried following to delete. But, Not working as expected.

const filteredFinalYearArr = yearArray.filter(function (el) {
  return el != null;
});

Note: This is dynamic data

Any suggestions?

1

3 Answers 3

11

You could filter all the objects which have non-zero number of keys:

let yearArray = [{},{},{},{label:'2015',showLabels:'1,'},{},{},{},{label:'2017',showLabels:'1,'}]

let filtered = yearArray.filter(el => Object.keys(el).length)

console.log(filtered)

1

See this article about best ways to check if an Object is empty.

const years = [
  {},
  {},
  {},
  { label: '2015', showLabels: '1,' },
  {},
  {},
  {},
  { label: '2017', showLabels: '1,' }
]

const hasValues = obj => {
  for(var key in obj) {
    if(obj.hasOwnProperty(key)) return true
  }
  return false
}

const filteredYears = years.filter(y => hasValues(y))

console.log(filteredYears)

2
  • "Object.keys(obj).length is not supported on Firefox < 4 and IE < 9" Neither are arrow functions. OP is using react native. So, they will have traspilers or polyfills to support old browsers :)
    – adiga
    Commented Mar 26, 2019 at 15:26
  • @adiga oh yeah. thanks for pointing out. serves me right eh? :-D Commented Mar 26, 2019 at 15:30
0

Another way is to use reduce to build the array.

const yearArray = [{},{},{},{label:'2015',showLabels:'1,'},{},{},{},{label:'2017',showLabels:'1,'}]

const filteredFinalYearArr = yearArray.reduce((o, i) => {Object.keys(i).length > 0 && o.push(i); return o}, [])

console.log(filteredFinalYearArr)

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.