1

I have a list of buttons, each button represents some data from my backend.

Now when I press two of these buttons I need to mark them and also all buttons in between red.

const Buttons = () => {
  const data = useState(getData())[0];
  const [pressedButtons, setPressedButtons] = useState([]);

  return ({data.map((buttonData, index) => 
    <Pressable
        style={{backgroundColor: pressedButtons.indexOf(index) > -1 ? "red" : "white"}}
        onPress={(index) => setPressedButtons(calculatePressedButtons(index))}>
      <Text>{buttonData.getText()}</Text>
    </Pressable>
  });
}

The problem with this approach is that when having many buttons like this (100+) whenever I need to update a single button the whole component is re-rendered which then results in a delayed feedback to pressing the button.

I've been looking for a solution, but the proposed ones (mostly with memo) don't seem to apply to my case. The parent still goes through all this map and recalculates props for each button.

How can I efficiently update the components so that the feedback to the button clicks is instant?

2 Answers 2

1

make each button a separate component and each one handles its own state internally. then pass a callback to your button component thet every time you pressed the button, aside from updating your button state, that callback will be called. after that you can use forwardRef and useHandleImperative api to expose your onclick functionality to the parent and using ref for every button component in the parent and in the callback you passed in the previous step specify which buttons shoud be updated afer a button has been clicked.

Sign up to request clarification or add additional context in comments.

1 Comment

code exemple would be needed here
0

I think you should make each button a separate component and each one handles its state internally

5 Comments

I need to update not only the button that was pressed but also the buttons between the last selected buttons (similar to selecting two files with Shift)
my solution is to pass a callback to your button component thet every time you pressed the button, aside from updating your button state, that callback will be called
after that you can use forwardRef and useHandleImperative api to expose your onclick functionality to the parent and using ref for every button component in the parent and in the callback you passed in the previous step specify which buttons shoud be updated afer a button has been clicked
I'm happy I coluld help you. can you please rate my answer as a true answer?
please add the info from comments to the answer, as they are the true answer (the more explained the better) and I will be happy to accept it ;)

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.