Follow

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use
Contact

How can I get objects in my array to only show up once? JavaScript

Hey I’m struggling and was hoping that maybe someone here could help. I’m making a web app that uses a big array of objects that looks similar to this:

var arr = [
{
    prop1 : "foo",
    prop2 : ["foo1", "foo2", "foo3", "foo4"],
    prop3 : "foo5",
    prop4 : "foo6",
},
{
    prop1 : "bar",
    prop2 : ["bar1", "bar2", "bar3", "bar4"],
    prop3 : "bar5",
    prop4 : "bar6",
}, 
{
    prop1 : "something",
    prop2 : ["something1", "something2", "something3", "something4"],
    prop3 : "something5",
    prop4 : "something6",
}
]

The array is much bigger than that but you get the idea. I want to display only 5 objects from the array at random each time the code is run which I did like this:

randomArr = arr.sort(() => Math.random() - .5);
spliceArr = randomArr.splice(5);

It works, but it sometimes shows objects from the main array multiple times. How can I write the code so the it will return objects from the array only once?

MEDevel.com: Open-source for Healthcare and Education

Collecting and validating open-source software for healthcare, education, enterprise, development, medical imaging, medical records, and digital pathology.

Visit Medevel

>Solution :

You could solve this by creating an array of unique random indicies, then return an array of objects that correspond to those random indices.

A set can be used to ensure at most only one index exists.

function getNRandomObjects(objectArray,numberOfObjects) {

  // use a set to ensure at most only one instance of an index is
  // generated
  const indices = new Set();

  while(indices.size < numberOfObjects) {
    //generate a random index and add it to the set
    indices.add( Math.floor(Math.random() * objectArray.length));
  }

  // convert the set of indices into an array, 
  // then use map to return a new array of objects 
  // corresponding to those indices.
  return Array.from(indices).map(i=>objectArray[i]);
}
Add a comment

Leave a Reply

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use

Discover more from Dev solutions

Subscribe now to keep reading and get access to the full archive.

Continue reading