אני לא מאמין ששוב טעיתי ב useEffect
יום אחד אני אפתח מוזיאון לכל הטעויות המוזרות שאני עושה עם useEffect. בינתיים אתם מוזמנים להציץ בקוד השבור שאני כתבתי ולראות כמה זמן לוקח לכם למצוא את הבעיה.
הקוד משתמש ב ResizeObserver כדי להריץ קוד כל פעם שהגודל של אלמנט מסוים שהוא מסתכל עליו משתנה:
import React, { useEffect } from 'react';
// trackedRef is a reference to a DOM element
export default function ResizeHandler({ trackedRef }) {
useEffect(() => {
const resizeObserver = new ResizeObserver(() => {
const height = trackedRef.current.scrollHeight;
console.log(`Your new height is: ${height}`);
});
resizeObserver.observe(trackedRef.current);
return function cancel() {
resizeObserver.disconnect();
}
}, [trackedRef]);
return <></>;
}
רואים את הבאג? מוזמנים לשתף בתגובות ולהיזהר מסכינים חדות.
(נ.ב. מכל הפונקציות של ריאקט, useEffect היתה בשבילי אהבה ממבט ראשון. הגעתי אליה עם הטראומה של הכפילות בין componentDidMount
ו componentDidUpdate
וחשבתי שהנה יש פיתרון לכל הצרות שלי במקום אחד. בפועל חוסר תשומת לב כמו בדוגמה כאן גורם לי לייצר אינסוף באגים יצירתיים בעבודה איתה. במקרה הזה למרות שהשתמשתי ב eslint ולמרות ש eslint כולל כלל ספציפי להתמודדות עם הבאג בקוד המודבק הוא עדיין התעלם מהטעות ולא הזהיר. אין לי פה המלצות קסם חוץ מלהיות מאוד זהירים בעבודה עם useEffect, לכתוב אפקטים קצרים ולא יותר מדי מהם ולקוות שבאיטרציה הבאה של ריאקט דן אברמוב יבוא עם מנגנון יותר ידידותי).