Home > OS >  Only push the object which is not in the array yet
Only push the object which is not in the array yet

Time:10-24

This is my function:

const multiSelect = value => {
    let tmpArr = [...selectedPeople];

    if (tmpArr.length === 0) {
      tmpArr.push(value);
    } else {
      tmpArr.map(item => {
        if (item.id !== value.id) {
          tmpArr.push(value);
        } else {
          return;
        }
      });
    }
    setSelectedPeople(tmpArr);
  };

I want to check the array for the new value by comparing it with all items. If value === item item the loop function should return, but if the value is not in the array yet, it should push it.

This is a big problem for me but I assume it is a small problem for you guys.

CodePudding user response:

Use Array.every() to check if the array doesn't contain an item with the same id:

const multiSelect = value => {
  const tmpArr = [...selectedPeople];
  
  if(tmpArr.every(item => item.id !== value.id)) {
    tmpArr.push(value);
  }

  setSelectedPeople(tmpArr);
};

However, this means that you're duplicating the array needlessly, while causing a re-render, that won't do a thing. So check if the item is already a part of selectedPeople by using Array.some(), and if it does use return to exit the function early. If it's not continue with cloning, and updating the state:

const multiSelect = value => {
  if(tmpArr.some(item => item.id === value.id)) {
    return;
  }

  const tmpArr = [...selectedPeople];
  
  tmpArr.push(value);

  setSelectedPeople(tmpArr);
};

CodePudding user response:

Use find to check if the item is already in the array. Also, there's no need to make a copy of the source array:

const multiSelect = value => {
    if (!selectedPeople.find(item => item.id === value.id))
        setSelectedPeople(selectedPeople.concat(value))
}

CodePudding user response:

Another approach.

const
    multiSelect = value => setSelectedPeople([
        ...selectedPeople,
        ...selectedPeople.some(({ id }) => id === value.id)
            ? []
            : [value]
    ]);
  • Related