בין הצעקות הראשונות שאנחנו פוגשים בקונסול כשכותבים ריאקט נמצאת הצעקה:
Warning: Invalid DOM property `class`. Did you mean `className`?
אבל כבר כמה שנים למרות האזהרה הקוד עדיין עובד. כלומר בקומפוננטה הזו:
import "./styles.css";
export default function App() {
return (
<div class="App">
<h1>Hello CodeSandbox</h1>
<h2>Start editing to see some magic happen!</h2>
</div>
);
}
ל div המרכזי יהיה את הקלאס App.
אז מה בכל זאת הבעיה? מסתבר שהסיפור הוא בכלל לא מגבלה טכנית של ריאקט אלא ניסיון להגן עלינו המתכנתים. בשביל לכתוב קומפוננטה שמקבלת בתור prop מאפיין class יכול להיות שהיינו מנסים לכתוב קוד כזה:
export default function App(props) {
const { class } = props;
}
שלא היה עובד בגלל ש class זו מילה שמורה.
וכן ברור שהיינו יכולים לכתוב במקום משהו כזה:
export default function App(props) {
const { class: className } = props;
// now I use className inside the component, to handle the "class" from outside
}
אבל אף אחד לא רוצה לשנות עכשיו את כל הקוד של קומפוננטות קיימות.
ולמה לא לתמוך בשני הכתיבים (מה שכבר קורה עכשיו) בלי אזהרה? התשובה שאם לא היתה אזהרה אז כל ספריית קומפוננטות היתה צריכה לתמוך בשני הכתיבים וזה שוב יכריח כותבי ספריות לשכתב הרבה קוד.