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

राज्य के टेस्टकेस में ReactDOM.unstable_batchedUpdates।

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

इस लेख में, हम एक परीक्षण मामले में ReactDOM.unstable_batchedUpdates के उपयोग पर गौर करेंगे, विशेष रूप से रिएक्ट के लिए एक लोकप्रिय राज्य प्रबंधन लाइब्रेरी ज़स्टैंड में। हम परीक्षण का भी विश्लेषण करेंगे और बताएंगे कि कैसे बैच किए गए अपडेट अनावश्यक री-रेंडर को कम करके रिएक्ट में प्रदर्शन को बढ़ाते हैं।

टेस्ट केस को समझना

यहां वह परीक्षण मामला है जिसकी हम जांच करेंगे:

ReactDOM.unstable_batchedUpdates in Zustand’s testcase.

यह परीक्षण केस यह सत्यापित करने के लिए लिखा गया है कि रिएक्ट के रेंडरिंग सिस्टम के साथ ज़स्टैंड का उपयोग करते समय बैचेड अपडेट लागू किए जा सकते हैं।

टेस्ट केस को तोड़ना

1. ज़स्टैंड स्टोर सेटअप: पहले चरण में क्रिएट फ़ंक्शन का उपयोग करके एक ज़स्टैंड स्टोर बनाना शामिल है:

const useBoundStore = create(
  (set) => ({   
  count: 0,   
  inc: () => set((state) => ({ count: state.count   1 })), }))

यहां, स्टोर एक सरल स्थिति बनाए रखता है जिसमें गिनती संपत्ति 0 से शुरू होती है और गिनती बढ़ाने के लिए एक इंक फ़ंक्शन होता है। सेट फ़ंक्शन, रिएक्ट में सेटस्टेट के समान, ज़स्टैंड का राज्य को अपडेट करने का तरीका है।

2. काउंटर घटक: काउंटर घटक वर्तमान गणना और इंक फ़ंक्शन को पुनः प्राप्त करने के लिए यूज़बाउंडस्टोर का उपयोग करता है:

const { count, inc } = useBoundStore()

यह घटक स्टोर की स्थिति की सदस्यता लेता है, और गिनती में कोई भी बदलाव इसे नए मूल्य के साथ फिर से प्रस्तुत करने का कारण बनेगा।

3. प्रदर्शन के लिए ReactDOM.unstable_batchedUpdates का उपयोग करना: यूज़इफेक्ट हुक के अंदर, इंक फ़ंक्शन को ReactDOM.unstable_batchedUpdates ब्लॉक के भीतर दो बार कॉल किया जाता है:

useEffect(() => {   
  ReactDOM.unstable_batchedUpdates(() => {     
    inc()     
    inc()   
  }) 
}, [inc])

यहां जादू पैदा होता है। आम तौर पर, inc() पर प्रत्येक कॉल एक अलग अपडेट ट्रिगर करेगी, जिससे दो रेंडर होंगे। हालाँकि, इन कॉल्स को अस्थिर_बैच्डअपडेट्स में लपेटकर, रिएक्ट उन्हें एक ही अपडेट में एक साथ संसाधित करने में सक्षम है, जिसके परिणामस्वरूप केवल एक रेंडर होता है। यह रेंडरर्स की संख्या को कम करके प्रदर्शन को अनुकूलित करता है, जो प्रदर्शन-महत्वपूर्ण अनुप्रयोगों में विशेष रूप से उपयोगी है।

4. घटक का प्रतिपादन और परिणाम का दावा करना अंत में, घटक का प्रतिपादन किया जाता है, और परीक्षण गिनती 2 तक पहुंचने की प्रतीक्षा करता है:

const { findByText } = render(
       
    >, 
)  

await findByText('count: 2')

यह दावा सुनिश्चित करता है कि दो वृद्धियों के बाद, गिनती सही ढंग से अद्यतन की जाती है और "गिनती: 2" के रूप में प्रस्तुत की जाती है।

ReactDOM.unstable_batchedUpdates क्या है?

ReactDOM.unstable_batchedUpdates रिएक्ट द्वारा प्रदान की गई एक विधि है जो एक ही रेंडर चक्र में कई राज्य अपडेट को संसाधित करने की अनुमति देती है। डिफ़ॉल्ट रूप से, रिएक्ट बैच अपडेट इवेंट हैंडलर (उदाहरण के लिए, क्लिक इवेंट) के अंदर ट्रिगर होता है, जिसका अर्थ है कि यदि आप उपयोगकर्ता इंटरैक्शन के जवाब में कई राज्यों को अपडेट करते हैं, तो रिएक्ट घटक को केवल एक बार प्रस्तुत करेगा। हालाँकि, ईवेंट हैंडलर के बाहर (जैसे सेटटाइमआउट या यूज़इफ़ेक्ट के भीतर), अपडेट स्वचालित रूप से बैच नहीं किए जाते हैं।

लेकिन रिएक्ट 18 के बाद यह बदल गया है। नीचे React.dev से लिए गए स्क्रीनशॉट हैं

ReactDOM.unstable_batchedUpdates in Zustand’s testcase.

ReactDOM.unstable_batchedUpdates in Zustand’s testcase.

ध्यान रखें, दस्तावेज़ीकरण से पता चलता है कि टाइमआउट, वादों, मूल ईवेंट हैंडलर या किसी अन्य ईवेंट के अंदर के अपडेट उसी तरह बैच होंगे जैसे कि रिएक्ट ईवेंट के अंदर के अपडेट। लेकिन इस Zustand के परीक्षण मामले में, बैच अपडेट को useEffect` के अंदर लागू किया जाता है। यह वह जगह है जहां अस्थिर_बैच अपडेट उपयोगी हो जाता है। यह रिएक्ट को कई राज्यों के अपडेट को एक ही रेंडर में समूहित करने के लिए मजबूर करता है, यहां तक ​​कि इवेंट-संचालित संदर्भों के बाहर भी, री-रेंडर को कम करने और प्रदर्शन में सुधार करने के लिए।

उदाहरण:

अस्थिर_बैच अपडेट के बिना:

inc()  // triggers one render
inc()  // triggers another render

अस्थिर_बैच अपडेट के साथ:

ReactDOM.unstable_batchedUpdates(() => {
  inc()  // triggers only one render for both updates
  inc()
})

इस विधि को "अस्थिर" लेबल किया गया है क्योंकि यह रिएक्ट की आधिकारिक सार्वजनिक एपीआई का हिस्सा नहीं है, लेकिन यह अभी भी प्रदर्शन अनुकूलन के लिए समुदाय में व्यापक रूप से उपयोग किया जाता है। यह भविष्य में रिएक्ट की नई समवर्ती रेंडरिंग क्षमताओं के हिस्से के रूप में अधिक स्थिर या एकीकृत हो सकता है।

मजेदार तथ्य: ज़स्टैंड की 4.5.5 रिलीज़ संस्करण का उपयोग करती है - 19.0.0-आरसी.0

ReactDOM.unstable_batchedUpdates in Zustand’s testcase.

Zustand में ReactDOM.unstable_batchedUpdates का उपयोग क्यों करें?

ज़स्टैंड एक हल्का राज्य प्रबंधन पुस्तकालय है जो रिएक्ट के घटक जीवनचक्र के साथ काम करता है। हालाँकि Zustand कुशलतापूर्वक राज्य अपडेट को संभालता है, रिएक्ट की प्रतिक्रिया प्रणाली हर बार राज्य बदलने पर रेंडर को ट्रिगर करेगी। ऐसे परिदृश्यों में जहां छोटी अवधि में कई स्थिति परिवर्तन होते हैं, ReactDOM.unstable_batchedUpdates का उपयोग करके कई पुन: रेंडरर्स को रोका जा सकता है और अपडेट को बैच किया जा सकता है, जिससे एक सहज, अधिक कुशल उपयोगकर्ता अनुभव की अनुमति मिलती है।

प्रदान किए गए परीक्षण मामले में, बैच अपडेट के भीतर दो बार इंक को कॉल करने से यह सुनिश्चित होता है कि गिनती केवल एक बार अपडेट होती है, जिससे प्रत्येक अपडेट को व्यक्तिगत रूप से चलाने की तुलना में यह अधिक कुशल हो जाता है।

हमारे बारे में:

थिंक थ्रू में, हम ओपन-सोर्स परियोजनाओं में उपयोग की जाने वाली उन्नत कोडबेस वास्तुशिल्प अवधारणाओं को सिखाने के मिशन पर हैं।

नेक्स्ट.जेएस/रिएक्ट में उन्नत वास्तुशिल्प अवधारणाओं का अभ्यास करके अपने कोडिंग कौशल को 10 गुना करें, सर्वोत्तम प्रथाओं को सीखें और उत्पादन-ग्रेड परियोजनाओं का निर्माण करें।

हम खुले स्रोत हैं - https://github.com/thinkthroo/thinkthroo (हमें एक स्टार अवश्य दें!)

कोडबेस आर्किटेक्चर पर आधारित हमारे उन्नत पाठ्यक्रमों के साथ अपनी टीम को कुशल बनाएं। अधिक जानने के लिए [email protected] पर हमसे संपर्क करें!

संदर्भ:

  1. https://github.com/pmndrs/zustand/blob/v4.5.5/tests/basic.test.tsx#L175C7-L175C39

  2. https://dev.to/devmoustafa97/do-you-know-unstablebatchedupdates-in-react-enforce-batching-state-update-5cn2

  3. https://dev.to/jackbuchananconroy/react-18-what-s-changed-automatic-batching-13ec

  4. https://react.dev/blog/2022/03/08/react-18-upgrade-guide#automatic-batching

  5. https://github.com/pmndrs/zustand/blob/v4.5.5/package.json#L246C4-L247C32



विज्ञप्ति वक्तव्य यह लेख यहां पुन: प्रस्तुत किया गया है: https://dev.to/thinkthroo/reactdomunstablebatchedupdates-in-zustands-testcase-4led?1 यदि कोई उल्लंघन है, तो कृपया इसे हटाने के लिए स्टडी_गोलंग@163.com से संपर्क करें।
नवीनतम ट्यूटोरियल अधिक>

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

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

Copyright© 2022 湘ICP备2022001581号-3