"यदि कोई कर्मचारी अपना काम अच्छी तरह से करना चाहता है, तो उसे पहले अपने औजारों को तेज करना होगा।" - कन्फ्यूशियस, "द एनालेक्ट्स ऑफ कन्फ्यूशियस। लू लिंगगोंग"
मुखपृष्ठ > प्रोग्रामिंग > रिएक्ट में यूज़स्टेट के साथ डेवलपर्स द्वारा की जाने वाली सामान्य गलतियाँ (और उन्हें कैसे ठीक करें)

रिएक्ट में यूज़स्टेट के साथ डेवलपर्स द्वारा की जाने वाली सामान्य गलतियाँ (और उन्हें कैसे ठीक करें)

2024-11-03 को प्रकाशित
ब्राउज़ करें:442

Common Mistakes Developers Make with useState in React (And How to Fix Them)

रिएक्ट का उपयोगस्टेट हुक कार्यात्मक घटकों में राज्य के प्रबंधन के लिए एक आवश्यक उपकरण है, लेकिन कुछ सामान्य नुकसानों में फंसना आसान है। चाहे आप अभी रिएक्ट के साथ शुरुआत कर रहे हों या कुछ समय से इसके साथ काम कर रहे हों, इन गलतियों से बचना आपको अप्रत्याशित बग और प्रदर्शन समस्याओं से बचा सकता है।

आइए 10 बार-बार होने वाली गलतियों के बारे में जानें और आप उनसे कैसे बचकर स्वच्छ और अधिक कुशल कोड लिख सकते हैं।

1. ग़लत आरंभिक अवस्था प्रकार

सबसे आम समस्याओं में से एक तब उत्पन्न होती है जब प्रारंभिक राज्य प्रकार राज्य अपडेट के दौरान अपेक्षित प्रकार से मेल नहीं खाता है।

❌ गलती: प्रारंभिक राज्य प्रकार बेमेल

const [count, setCount] = useState(0);
setCount("1"); // Error: Argument of type 'string' is not assignable to parameter of type 'number'.

✅ समाधान: टाइपस्क्रिप्ट का उपयोग करें या स्पष्ट रूप से प्रकार निर्दिष्ट करें।

const [count, setCount] = useState(0);
setCount(1); // No issues now.

2. कार्यात्मक अद्यतनों का उपयोग नहीं करना

पिछले मान के आधार पर स्थिति को अपडेट करते समय, वर्तमान स्थिति को सीधे संदर्भित करने से पुराने मान हो सकते हैं, खासकर एसिंक ऑपरेशंस में।

❌ गलती: सीधे वर्तमान स्थिति का उपयोग करना

setCount(count   1); // Can cause bugs in async scenarios.

✅ समाधान: सुरक्षित अपडेट के लिए कार्यात्मक फ़ॉर्म का उपयोग करें।

setCount((prevCount) => prevCount   1); // Ensures you always have the latest value.

3. व्युत्पन्न अवस्था का भंडारण

राज्य में उन मूल्यों को संग्रहीत करने से बचें जो अन्य राज्य या प्रॉप्स से प्राप्त किए जा सकते हैं। इससे अनावश्यक री-रेंडर और सिंक्रोनाइज़ेशन समस्याएं हो सकती हैं।

❌ गलती: व्युत्पन्न स्थिति संग्रहीत करना

const [count, setCount] = useState(0);
const [doubleCount, setDoubleCount] = useState(count * 2);

✅ समाधान: राज्य का उपयोग करने के बजाय रेंडर के दौरान मूल्य प्राप्त करें।

const [count, setCount] = useState(0);
const doubleCount = count * 2; // No need to store this in state.

4. रेंडर चरण के अंदर राज्य अपडेट

रेंडर चरण के अंदर सेटस्टेट को कॉल करना अनंत लूप और प्रदर्शन समस्याओं के लिए एक नुस्खा है।

❌ गलती: रेंडर के दौरान स्थिति सेट करना

const [count, setCount] = useState(0);
setCount(1); // Infinite loop!

✅ समाधान: इवेंट हैंडलर या प्रभावों में ट्रिगर स्थिति में परिवर्तन होता है।

const handleClick = () => setCount(1);

5. प्रत्यक्ष रूप से परिवर्तनशील अवस्था

यदि आप सीधे राज्य को बदलते हैं, खासकर सरणियों या वस्तुओं के साथ, तो रिएक्ट परिवर्तनों का पता नहीं लगाएगा।

❌ गलती: राज्य को सीधे परिवर्तित करना

const [items, setItems] = useState([1, 2, 3]);
items.push(4); // Mutation happens here, React won’t re-render!

✅ समाधान: पुनः रेंडरर्स को ट्रिगर करने के लिए एक नई सरणी या ऑब्जेक्ट लौटाएं।

setItems((prevItems) => [...prevItems, 4]); // Spread to create a new array.

6. जटिल अवस्था के लिए अपरिभाषित या गलत प्रकार

जटिल स्थिति से निपटते समय, उचित प्रकारों को परिभाषित नहीं करने से रनटाइम समस्याएं और भ्रम पैदा हो सकता है।

❌ गलती: अंतर्निहित प्रकार त्रुटियों का कारण बन सकते हैं

const [user, setUser] = useState({ name: "", age: 0 });
setUser({ name: "John", age: "thirty" }); // Type error: Age should be a number.

✅ समाधान: राज्य के आकार को सही प्रकार से परिभाषित करें।

type User = { name: string; age: number };
const [user, setUser] = useState({ name: "", age: 0 });

7. परिवर्तनशील मूल्यों के लिए राज्य का उपयोग करना (टाइमर की तरह)

उन मानों के लिए यूज़स्टेट का उपयोग करना जो रेंडरिंग को प्रभावित नहीं करते हैं, जैसे टाइमर, अनावश्यक पुन: रेंडरिंग की ओर ले जाता है।

❌ गलती: परिवर्तनशील मानों के लिए राज्य का उपयोग करना

const [timerId, setTimerId] = useState(null);

✅ समाधान: उन परिवर्तनशील मानों के लिए यूज़रेफ का उपयोग करें जिन्हें पुन: प्रस्तुत करने की आवश्यकता नहीं है।

const timerIdRef = useRef(null);

8. राज्य की वस्तुओं का ठीक से विलय न करना

क्लास घटकों के विपरीत, यूज़स्टेट अपडेट को स्वचालित रूप से मर्ज नहीं करता है। इसे भूलने से आपके राज्य के कुछ हिस्सों पर अधिलेखन हो सकता है।

❌ गलती: विलय के बजाय राज्य को ओवरराइट करना

const [user, setUser] = useState({ name: '', age: 0 });
setUser({ age: 25 }); // The 'name' field is now lost!

✅ समाधान: राज्य अपडेट को मर्ज करने के लिए स्प्रेड ऑपरेटर का उपयोग करें।

setUser((prevUser) => ({ ...prevUser, age: 25 })); // Merges with existing state.

9. उच्च-आवृत्ति अपडेट के लिए राज्य का उपयोग करना

राज्य में विंडो आयाम जैसे उच्च-आवृत्ति मानों को ट्रैक करने से अत्यधिक पुन: प्रस्तुतीकरण के कारण प्रदर्शन संबंधी समस्याएं हो सकती हैं।

❌ गलती: लगातार अपडेट के लिए राज्य का उपयोग करना

const [size, setSize] = useState(window.innerWidth);
window.addEventListener("resize", () => setSize(window.innerWidth));

✅ समाधान: प्रदर्शन प्रभावित को कम करने के लिए यूज़रेफ या डिबाउंस का उपयोग करें।

const sizeRef = useRef(window.innerWidth);
useEffect(() => {
  const handleResize = () => {
    sizeRef.current = window.innerWidth;
  };
  window.addEventListener("resize", handleResize);
  return () => window.removeEventListener("resize", handleResize);
}, []);

10. यह मानते हुए कि राज्य अद्यतन समकालिक हैं

प्रतिक्रिया स्थिति अपडेट अतुल्यकालिक हैं, लेकिन कई डेवलपर्स गलती से मान लेते हैं कि परिवर्तन तुरंत लागू होते हैं।

❌ गलती: यह मान लेना कि राज्य में परिवर्तन तत्काल हैं

setCount(count   1);
console.log(count); // Logs the old value, not the updated one!

✅ समाधान: स्थिति परिवर्तनों को ट्रैक करने और नवीनतम मान का उपयोग सुनिश्चित करने के लिए यूज़इफ़ेक्ट का उपयोग करें।

useEffect(() => {
  console.log(count); // Logs the updated value after re-render.
}, [count]);

अंतिम विचार?

इन यूज़स्टेट नुकसानों से बचने से आपका रिएक्ट कोड अधिक मजबूत, पठनीय और निष्पादन योग्य बन जाएगा। यह समझना कि रिएक्ट का राज्य तंत्र कैसे काम करता है और सर्वोत्तम प्रथाओं को जानने से आपका डिबगिंग में समय बचेगा और आपके समग्र विकास अनुभव में वृद्धि होगी।

क्या आपके पास साझा करने के लिए कोई उपयोगी सुझाव या गलतियाँ हैं? उन्हें नीचे टिप्पणी में लिखें! ?

विज्ञप्ति वक्तव्य यह आलेख यहां पुन: प्रस्तुत किया गया है: https://dev.to/ujjwalkar21/common-mistakes-developers-make-with-usestate-in-react-and-how-to-fix-them-1cmi?1 यदि कोई उल्लंघन है , कृपया स्टडी_गोलंग @163.कॉमडिलीट से संपर्क करें
नवीनतम ट्यूटोरियल अधिक>

चीनी भाषा का अध्ययन करें

अस्वीकरण: उपलब्ध कराए गए सभी संसाधन आंशिक रूप से इंटरनेट से हैं। यदि आपके कॉपीराइट या अन्य अधिकारों और हितों का कोई उल्लंघन होता है, तो कृपया विस्तृत कारण बताएं और कॉपीराइट या अधिकारों और हितों का प्रमाण प्रदान करें और फिर इसे ईमेल पर भेजें: [email protected] हम इसे आपके लिए यथाशीघ्र संभालेंगे।

Copyright© 2022 湘ICP备2022001581号-3