useEffect being weir - EventListener
So... I have this listener that listens for the position of selectedItem when I scroll on its parent. Why is it not unbinding when selectedItem changes? the cleanup function doesn't work. I have no idea of what is wrong lol.
when I change the selectedItem, it creates a new listener for that and they keep stacking.
please send help. images attached.
data:image/s3,"s3://crabby-images/89588/895887a261834c1a13358abcca8e03aa8123e0da" alt=""
data:image/s3,"s3://crabby-images/d52e1/d52e14561245c079df90dbff97c1f4e83f3ba88b" alt=""
data:image/s3,"s3://crabby-images/0a9a5/0a9a554a5bc3ebcb767baa489eb8293901dce73d" alt=""
8 Replies
You need to pass the same function
Make the handler a function and pass it both places
Also dont use images for code
Yeah that is not working also
Show
function printNumberFive() {
console.log(5);
}
useEffect(() => {
scrollRef.current!.addEventListener("scroll", () => {
printNumberFive();
});
return () => {
scrollRef.current!.removeEventListener("scroll", () => {
printNumberFive();
});
};
}, [selectedItem]);
Still 2 different references
Just pass printNumberFive
do you mean on the cleanup?
both
oh shit
trying it
cool
thx
it worked