Salesforce LWC साठी CSS @track डेकोरेटरसाठी एक सर्वसमावेशक मार्गदर्शक, कार्यक्षम डेटा बदलांचे ट्रॅकिंग आणि रेंडरिंगद्वारे कार्यप्रदर्शन ऑप्टिमायझेशनमध्ये त्याची भूमिका शोधणे.
CSS @track: कार्यक्षम डेटा बाइंडिंगसह वेब कार्यप्रदर्शन वाढवणे
आधुनिक वेब डेव्हलपमेंटच्या क्षेत्रात, विशेषतः लाइटनिंग वेब कंपोनंट्स (LWC) वापरून Salesforce इकोसिस्टममध्ये, कार्यप्रदर्शन अत्यंत महत्त्वाचे आहे. वापरकर्त्यांना जलद, प्रतिसाद देणारे आणि अखंड अनुभव अपेक्षित असतात. LWC मध्ये उत्कृष्ट कार्यप्रदर्शन मिळवण्यासाठी एक शक्तिशाली साधन म्हणजे @track
डेकोरेटर. हा लेख @track
समजून घेण्यासाठी आणि कार्यक्षम डेटा बाइंडिंग आणि सुधारित वेब कार्यप्रदर्शनासाठी त्याचा वापर करण्यासाठी एक सर्वसमावेशक मार्गदर्शक आहे.
@track
डेकोरेटर म्हणजे काय?
LWC मधील @track
डेकोरेटरचा वापर कंपोनंटच्या जावास्क्रिप्ट क्लासमधील प्रॉपर्टीजमधील बदल ट्रॅक करण्यासाठी केला जातो. जेव्हा एखादी प्रॉपर्टी @track
ने डेकोरेट केली जाते, तेव्हा LWC चे रिॲक्टिव्ह इंजिन त्या प्रॉपर्टीमधील बदलांवर लक्ष ठेवते. जेव्हा बदल आढळतो, तेव्हा LWC कंपोनंटला पुन्हा रेंडर करते, नवीन डेटा दर्शवण्यासाठी यूजर इंटरफेस अद्यतनित करते.
याला एक विशेष निरीक्षक समजा. क्लिष्ट बदल ओळखण्याची यंत्रणा स्वतःहून लागू करण्याऐवजी, @track
LWC ला कोणत्या प्रॉपर्टीजमुळे अपडेट्स सुरू व्हायला हवेत हे सांगण्याचा एक घोषणात्मक आणि कार्यक्षम मार्ग प्रदान करते.
मुख्य संकल्पना: @track
चा धोरणात्मक वापर करून, आपण कोणते कंपोनंट अपडेट्स सुरू होतील हे नियंत्रित करू शकता, अनावश्यक रिरेंडरिंग कमी करू शकता आणि कार्यप्रदर्शन लक्षणीयरीत्या सुधारू शकता.
कार्यप्रदर्शनासाठी @track
महत्त्वाचे का आहे?
वेब ब्राउझर स्क्रीनवरील घटक सतत रेंडर आणि पुन्हा रेंडर करत असतात. ही प्रक्रिया संसाधन-केंद्रित असू शकते, विशेषतः मोठ्या प्रमाणात डेटा असलेल्या क्लिष्ट ॲप्लिकेशन्समध्ये. अनावश्यक रिरेंडरिंगमुळे खालील गोष्टी होऊ शकतात:
- गती कमी होणे: यूजर इंटरफेस मंद आणि प्रतिसाद न देणारा बनतो.
- CPU चा वाढलेला वापर: ब्राउझर अधिक प्रोसेसिंग पॉवर वापरतो, ज्यामुळे मोबाइल डिव्हाइसवरील बॅटरी लवकर संपू शकते.
- खराब वापरकर्ता अनुभव: वापरकर्ते मंद कार्यप्रदर्शनामुळे निराश होतात आणि ॲप्लिकेशन सोडून देऊ शकतात.
@track
कंपोनंट्स केव्हा पुन्हा रेंडर करायचे यावर अचूक नियंत्रण देऊन या समस्या कमी करण्यास मदत करते. @track
किंवा तत्सम यंत्रणांशिवाय, LWC ला बदलांसाठी अधिक वारंवार आणि संभाव्यतः अनावश्यक तपासण्या कराव्या लागतील, ज्यामुळे कार्यप्रदर्शन कमी होईल.
@track
कसे कार्य करते?
जेव्हा आपण एखाद्या प्रॉपर्टीला @track
ने डेकोरेट करता, तेव्हा LWC चे रिॲक्टिव्ह इंजिन एक प्रॉक्सी ऑब्जेक्ट तयार करते जो प्रॉपर्टीला रॅप करतो. हा प्रॉक्सी ऑब्जेक्ट प्रॉपर्टीचे मूल्य बदलण्याच्या कोणत्याही प्रयत्नांना अडवतो. जेव्हा बदल आढळतो, तेव्हा प्रॉक्सी ऑब्जेक्ट कंपोनंटच्या रिरेंडरिंगला चालना देतो.
महत्त्वाचा विचार: @track
फक्त प्रॉपर्टीच्या *मूल्या*मधील बदल ट्रॅक करते, प्रॉपर्टीमधील *अंतर्गत* बदल नाही, जर ती ऑब्जेक्ट किंवा ॲरे असेल. @track
चा प्रभावीपणे वापर कसा करायचा हे समजून घेण्यासाठी हा एक महत्त्वाचा फरक आहे.
@track
विरुद्ध पब्लिक प्रॉपर्टीज (@api
)
@track
ला @api
ने डेकोरेट केलेल्या पब्लिक प्रॉपर्टीजपासून वेगळे करणे महत्त्वाचे आहे. दोन्ही रिरेंडरिंगला चालना देऊ शकतात, परंतु त्यांचे उद्देश भिन्न आहेत:
@track
: कंपोनंटमधील खाजगी प्रॉपर्टीजमधील बदल ट्रॅक करण्यासाठी वापरले जाते. या प्रॉपर्टीजमधील बदल सामान्यतः कंपोनंटद्वारेच सुरू केले जातात.@api
: पब्लिक प्रॉपर्टीज परिभाषित करण्यासाठी वापरले जाते ज्यांना पॅरेंट कंपोनंट्स किंवा बाह्य सिस्टमद्वारे (उदा. एपेक्स किंवा इतर लाइटनिंग कंपोनंट्समधून) ॲक्सेस आणि सुधारित केले जाऊ शकते.
@api
प्रॉपर्टीजमधील बदल *नेहमीच* रिरेंडरला चालना देतील, कारण ते कंपोनंटचा पब्लिक इंटरफेस दर्शवतात. @track
तुम्हाला अंतर्गत कंपोनंट स्थितीसाठी रिरेंडरिंगवर अधिक सूक्ष्म-नियंत्रण देते.
@track
केव्हा वापरावे
येथे काही सामान्य परिस्थिती आहेत जिथे @track
वापरणे फायदेशीर आहे:
- प्रिमिटिव्ह डेटा प्रकारांचा मागोवा घेणे: स्ट्रिंग, संख्या, बूलियन आणि तारखा यांसारख्या साध्या डेटा प्रकारांसाठी
@track
वापरा. या प्रकारांमधील बदल थेट ट्रॅक केले जातात आणि रिरेंडरला चालना देतील. - ऑब्जेक्ट्स आणि ॲरेंमधील बदलांचा मागोवा घेणे (अंशतः):
@track
ऑब्जेक्ट्स आणि ॲरेंमधील *अंतर्गत* बदल सखोलपणे ट्रॅक करत नसले तरी, ते ऑब्जेक्ट किंवा ॲरे *संदर्भा*मधील बदल ट्रॅक करते. याचा अर्थ असा की जर आपण@track
डेकोरेटेड प्रॉपर्टीला नवीन ऑब्जेक्ट किंवा ॲरे नियुक्त केल्यास, ते रिरेंडरला चालना देईल. - वापरकर्ता परस्परसंवादावर आधारित रेंडरिंग ऑप्टिमाइझ करणे: जर तुमच्याकडे असा कंपोनंट असेल जो वापरकर्त्याच्या क्रियांवर (उदा. बटण क्लिक, इनपुट बदल) आधारित अद्यतनित होतो, तर संबंधित डेटा बदलल्यावरच कंपोनंट पुन्हा रेंडर होईल याची खात्री करण्यासाठी
@track
वापरा.
@track
केव्हा वापरू नये (आणि पर्याय)
अशा काही परिस्थिती आहेत जिथे @track
सर्वात योग्य पर्याय असू शकत नाही, विशेषतः क्लिष्ट ऑब्जेक्ट्स आणि ॲरेंशी व्यवहार करताना. त्याचा चुकीचा वापर केल्यास अनपेक्षित वर्तन किंवा कार्यप्रदर्शन समस्या उद्भवू शकतात.
- खोलवर नेस्टेड ऑब्जेक्ट्स आणि ॲरे: आधी सांगितल्याप्रमाणे,
@track
फक्त ऑब्जेक्ट किंवा ॲरेच्या *संदर्भा*मधील बदल ट्रॅक करते, त्यातील *अंतर्गत* बदल नाही. जर तुम्ही खोलवर नेस्टेड ऑब्जेक्ट किंवा ॲरेमधील प्रॉपर्टीमध्ये बदल केल्यास, कंपोनंट पुन्हा रेंडर होणार *नाही*. - मोठे डेटासेट: खूप मोठ्या डेटासेटसह काम करताना,
@track
सह प्रत्येक बदल ट्रॅक करणे अकार्यक्षम होऊ शकते. पेजिनेशन, व्हर्च्युअलायझेशन किंवा विशेष डेटा स्ट्रक्चर्स वापरण्यासारख्या पर्यायी धोरणांचा विचार करा.
क्लिष्ट डेटासाठी @track
चे पर्याय:
- अपरिवर्तनीयता (Immutability): आपला डेटा अपरिवर्तनीय म्हणून हाताळा. विद्यमान ऑब्जेक्ट्स किंवा ॲरेंमध्ये बदल करण्याऐवजी, इच्छित बदलांसह नवीन तयार करा. हे सुनिश्चित करते की ऑब्जेक्ट संदर्भ बदलतो,
@track
प्रॉपर्टी अद्यतनित झाल्यावर रिरेंडरला चालना मिळते. Immer.js सारख्या लायब्ररी अपरिवर्तनीय डेटा व्यवस्थापनात मदत करू शकतात. - मॅन्युअल रिरेंडरिंग: काही प्रकरणांमध्ये, आपल्याला
renderedCallback()
लाइफसायकल हुक वापरून मॅन्युअली रिरेंडरला चालना द्यावी लागेल. हे आपल्याला रेंडरिंग प्रक्रियेवर पूर्ण नियंत्रण देते. तथापि, याचा वापर जपून करा, कारण ते आपला कोड अधिक क्लिष्ट बनवू शकते. - इव्हेंट हँडलिंग आणि लक्ष्यित अपडेट्स: प्रत्येक बदल ओळखण्यासाठी
@track
वर अवलंबून राहण्याऐवजी, कंपोनंटच्या विशिष्ट भागांना थेट अद्यतनित करण्यासाठी इव्हेंट हँडलिंग वापरण्याचा विचार करा. उदाहरणार्थ, जर वापरकर्त्याने सूचीतील एकाच आयटममध्ये बदल केल्यास, संपूर्ण सूची पुन्हा रेंडर करण्याऐवजी फक्त त्या आयटमचे व्हिज्युअल प्रतिनिधित्व अद्यतनित करा.
@track
वापरण्याची व्यावहारिक उदाहरणे
चला काही व्यावहारिक उदाहरणांसह @track
चा वापर स्पष्ट करूया.
उदाहरण १: एका साध्या काउंटरचा मागोवा घेणे
हे उदाहरण एक साधा काउंटर कसा ट्रॅक करायचा हे दर्शविते जो बटण क्लिक केल्यावर वाढतो.
जावास्क्रिप्ट (myComponent.js):
import { LightningElement, track } from 'lwc';
export default class MyComponent extends LightningElement {
@track counter = 0;
incrementCounter() {
this.counter++;
}
}
एचटीएमएल (myComponent.html):
Counter: {counter}
या उदाहरणात, counter
प्रॉपर्टी @track
ने डेकोरेट केलेली आहे. जेव्हा incrementCounter()
पद्धत कॉल केली जाते, तेव्हा counter
चे मूल्य वाढते, ज्यामुळे कंपोनंटचे रिरेंडरिंग होते आणि प्रदर्शित काउंटर मूल्य अद्यतनित होते.
उदाहरण २: ऑब्जेक्टमधील बदलांचा मागोवा घेणे (शॅलो ट्रॅकिंग)
हे उदाहरण दर्शविते की @track
ऑब्जेक्टच्या *संदर्भा*मधील बदल कसे ट्रॅक करते. ऑब्जेक्टमधील *अंतर्गत* प्रॉपर्टीजमध्ये बदल केल्यास रिरेंडर होणार *नाही*.
जावास्क्रिप्ट (myComponent.js):
import { LightningElement, track } from 'lwc';
export default class MyComponent extends LightningElement {
@track contact = {
firstName: 'John',
lastName: 'Doe'
};
updateFirstName() {
// This will NOT trigger a rerender
this.contact.firstName = 'Jane';
}
replaceContact() {
// This WILL trigger a rerender
this.contact = {
firstName: 'Jane',
lastName: 'Doe'
};
}
}
एचटीएमएल (myComponent.html):
First Name: {contact.firstName}
Last Name: {contact.lastName}
"Update First Name" बटण क्लिक केल्याने कंपोनंट पुन्हा रेंडर होणार *नाही* कारण @track
फक्त ऑब्जेक्ट *संदर्भा*मधील बदल ट्रॅक करते, ऑब्जेक्टमधील *अंतर्गत* बदल नाही. "Replace Contact" बटण क्लिक केल्याने रिरेंडर होईल कारण ते contact
प्रॉपर्टीला एक नवीन ऑब्जेक्ट नियुक्त करते.
उदाहरण ३: ऑब्जेक्टमधील बदलांचा मागोवा घेण्यासाठी अपरिवर्तनीयतेचा वापर करणे (डीप ट्रॅकिंग)
हे उदाहरण @track
वापरून ऑब्जेक्टमधील बदल प्रभावीपणे कसे ट्रॅक करायचे हे दर्शविण्यासाठी अपरिवर्तनीयतेचा वापर कसा करायचा हे स्पष्ट करते.
जावास्क्रिप्ट (myComponent.js):
import { LightningElement, track } from 'lwc';
export default class MyComponent extends LightningElement {
@track contact = {
firstName: 'John',
lastName: 'Doe'
};
updateFirstName() {
// Create a new object with the updated first name
this.contact = {
...this.contact,
firstName: 'Jane'
};
}
}
एचटीएमएल (myComponent.html):
First Name: {contact.firstName}
Last Name: {contact.lastName}
या उदाहरणात, updateFirstName()
पद्धत स्प्रेड ऑपरेटर (...
) वापरून अद्यतनित firstName
सह एक *नवीन* ऑब्जेक्ट तयार करते. हे सुनिश्चित करते की ऑब्जेक्ट संदर्भ बदलतो, ज्यामुळे contact
प्रॉपर्टी अद्यतनित झाल्यावर रिरेंडरला चालना मिळते.
@track
वापरण्यासाठी सर्वोत्तम पद्धती
@track
चे फायदे जास्तीत जास्त मिळवण्यासाठी आणि संभाव्य कार्यप्रदर्शन त्रुटी टाळण्यासाठी, या सर्वोत्तम पद्धतींचे अनुसरण करा:
@track
चा वापर जपून करा: फक्त त्या प्रॉपर्टीज डेकोरेट करा ज्यांना खरोखर रिरेंडरिंग सुरू करण्याची आवश्यकता आहे. ज्या प्रॉपर्टीज केवळ अंतर्गत गणनेसाठी किंवा तात्पुरत्या स्टोरेजसाठी वापरल्या जातात त्यांना ट्रॅक करणे टाळा.- अपरिवर्तनीयतेला प्राधान्य द्या: ऑब्जेक्ट्स आणि ॲरेंसह काम करताना, बदल योग्यरित्या ट्रॅक केले जातील याची खात्री करण्यासाठी अपरिवर्तनीयतेला प्राधान्य द्या. विद्यमान ऑब्जेक्ट्स आणि ॲरेंमध्ये बदल करण्याऐवजी नवीन तयार करण्यासाठी स्प्रेड ऑपरेटर किंवा Immer.js सारख्या लायब्ररींचा वापर करा.
- कंपोनंट पदानुक्रमाचा विचार करा: एका कंपोनंटमधील बदलांचा पदानुक्रमातील इतर कंपोनंट्सवर कसा परिणाम होऊ शकतो याचा विचार करा. कंपोनंट्समधील बदल संवाद साधण्यासाठी इव्हेंट्स वापरा आणि पॅरेंट कंपोनंट्सचे अनावश्यक रिरेंडरिंग टाळा.
- आपल्या कंपोनंट्सचे प्रोफाइल करा: आपल्या कंपोनंट्सचे प्रोफाइल करण्यासाठी आणि कार्यप्रदर्शन अडथळे ओळखण्यासाठी Salesforce Lightning Inspector वापरा. हे आपल्याला
@track
अकार्यक्षमतेने कुठे वापरले जात आहे किंवा कुठे पर्यायी ऑप्टिमायझेशन धोरणे अधिक योग्य असू शकतात हे ओळखण्यास मदत करू शकते. - पूर्णपणे चाचणी करा: आपले कंपोनंट्स योग्यरित्या पुन्हा रेंडर होत आहेत आणि यूजर इंटरफेस अपेक्षेप्रमाणे अद्यतनित होत आहे याची खात्री करण्यासाठी त्यांची पूर्णपणे चाचणी करा. विशेषतः एज केसेस आणि क्लिष्ट डेटा परिस्थितींकडे लक्ष द्या.
वास्तविक-जगातील परिस्थितींमध्ये @track
चला वास्तविक-जगातील Salesforce LWC परिस्थितींमध्ये @track
कसे वापरले जाऊ शकते ते पाहूया.
- डायनॅमिक फॉर्म्स: डायनॅमिक फॉर्म कंपोनंटमध्ये, आपण फॉर्म फील्डच्या मूल्यांचा मागोवा घेण्यासाठी
@track
वापरू शकता. जेव्हा वापरकर्ता फील्ड मूल्य बदलतो, तेव्हा कंपोनंट इतर फील्डचे प्रदर्शन अद्यतनित करण्यासाठी किंवा व्हॅलिडेशन करण्यासाठी पुन्हा रेंडर होतो. उदाहरणार्थ, "Country" फील्ड बदलल्याने "State/Province" फील्डमधील उपलब्ध पर्याय डायनॅमिकरित्या अद्यतनित होऊ शकतात. कॅनडासारख्या देशांचा विचार करा ज्यात प्रांत आहेत विरुद्ध युनायटेड स्टेट्स ज्यात राज्ये आहेत; प्रदर्शित केलेले पर्याय संदर्भित असले पाहिजेत. - परस्परसंवादी चार्ट आणि आलेख: जर आपण LWC मध्ये परस्परसंवादी चार्ट किंवा आलेख तयार करत असाल, तर आपण निवडलेल्या डेटा पॉइंट्स किंवा फिल्टर निकषांचा मागोवा घेण्यासाठी
@track
वापरू शकता. जेव्हा वापरकर्ता चार्टशी संवाद साधतो (उदा. बारवर क्लिक करून), तेव्हा कंपोनंट चार्टचे प्रदर्शन अद्यतनित करण्यासाठी किंवा निवडलेल्या डेटा पॉइंटबद्दल तपशीलवार माहिती दर्शविण्यासाठी पुन्हा रेंडर होतो. उत्तर अमेरिका, युरोप, आशिया-पॅसिफिक यांसारख्या विविध प्रदेशांसाठी डेटा प्रदर्शित करणाऱ्या सेल्स डॅशबोर्डची कल्पना करा. एक प्रदेश निवडल्याने त्या प्रदेशातील विक्री कामगिरीचे अधिक तपशीलवार दृश्य दर्शविण्यासाठी चार्ट अद्यतनित होतो. - रिअल-टाइम डेटा अपडेट्स: ज्या ॲप्लिकेशन्सना रिअल-टाइम डेटा अपडेट्सची आवश्यकता असते (उदा. स्टॉक टिकर्स, सेन्सर रीडिंग), तेथे आपण येणाऱ्या डेटाचा मागोवा घेण्यासाठी आणि त्यानुसार यूजर इंटरफेस अद्यतनित करण्यासाठी
@track
वापरू शकता. डेटा व्हॉल्यूम आणि अपडेट वारंवारतेचा विचार करून वापरा; अत्यंत उच्च-वारंवारतेच्या अपडेट्ससाठी पर्यायी दृष्टिकोन आवश्यक असू शकतात. उदाहरणार्थ, USD, EUR, JPY आणि GBP मधील रिअल-टाइम विनिमय दर प्रदर्शित करणारा कंपोनंट दर बदलल्यास ते अद्यतनित करण्यासाठी@track
वापरेल. - कस्टम शोध कंपोनंट्स: कस्टम शोध कंपोनंट तयार करताना, शोध संज्ञा आणि शोध परिणामांचा मागोवा घेण्यासाठी
@track
वापरले जाऊ शकते. वापरकर्ता शोध बॉक्समध्ये टाइप करत असताना, कंपोनंट शोध परिणाम अद्यतनित करण्यासाठी पुन्हा रेंडर होतो. हे विशेषतः उपयुक्त आहे जर शोध प्रदर्शित केलेल्या डेटावर फिल्टर आणि सॉर्ट देखील लागू करत असेल. विविध स्त्रोतांकडून डेटा मिळवणाऱ्या ग्लोबल शोध कंपोनंटचा विचार करा;@track
वापरल्याने वापरकर्त्याच्या इनपुटवर आधारित शोधाचे रिअल-टाइम परिष्करण शक्य होते.
@track
चे भविष्य आणि LWC मधील रिॲक्टिव्ह प्रोग्रामिंग
@track
डेकोरेटर LWC च्या रिॲक्टिव्ह प्रोग्रामिंग मॉडेलचा एक मूलभूत भाग आहे. LWC जसजसे विकसित होत राहील, तसतसे आपण रिॲक्टिव्ह इंजिनमध्ये आणखी सुधारणा आणि नवीन वैशिष्ट्ये पाहण्याची अपेक्षा करू शकतो जे उच्च-कार्यक्षमतेचे वेब ॲप्लिकेशन्स तयार करणे आणखी सोपे करतील.
संभाव्य भविष्यातील दिशा:
- सुधारित डीप ट्रॅकिंग: LWC च्या भविष्यातील आवृत्त्या ऑब्जेक्ट्स आणि ॲरेंमधील बदलांचा मागोवा घेण्यासाठी अधिक मजबूत यंत्रणा प्रदान करू शकतात, ज्यामुळे मॅन्युअल अपरिवर्तनीयता व्यवस्थापनाची गरज कमी होईल.
- रिरेंडरिंगवर अधिक सूक्ष्म नियंत्रण: LWC नवीन वैशिष्ट्ये सादर करू शकते जे विकासकांना कंपोनंट्स केव्हा आणि कसे पुन्हा रेंडर करायचे यावर अधिक सूक्ष्म-नियंत्रण ठेवण्याची परवानगी देतील, ज्यामुळे कार्यप्रदर्शन आणखी ऑप्टिमाइझ होईल.
- रिॲक्टिव्ह लायब्ररींसह एकत्रीकरण: LWC RxJS किंवा MobX सारख्या लोकप्रिय रिॲक्टिव्ह लायब्ररींसह अधिक अखंडपणे एकत्रित होऊ शकते, ज्यामुळे विकासकांना डेटा प्रवाह आणि कंपोनंट अपडेट्स व्यवस्थापित करण्यासाठी विस्तृत साधने मिळतील.
निष्कर्ष
@track
डेकोरेटर Salesforce LWC मध्ये वेब कार्यप्रदर्शन ऑप्टिमाइझ करण्यासाठी एक शक्तिशाली साधन आहे. ते कसे कार्य करते हे समजून घेऊन आणि सर्वोत्तम पद्धतींचे अनुसरण करून, आपण प्रतिसाद देणारे आणि कार्यक्षम ॲप्लिकेशन्स तयार करू शकता जे एक उत्कृष्ट वापरकर्ता अनुभव देतात. @track
चा धोरणात्मक वापर करणे, अपरिवर्तनीयतेला प्राधान्य देणे, आणि संभाव्य कार्यप्रदर्शन अडथळे ओळखण्यासाठी आपल्या कंपोनंट्सचे प्रोफाइल करणे लक्षात ठेवा. LWC जसजसे विकसित होत राहील, तसतसे उच्च-कार्यक्षमतेचे वेब ॲप्लिकेशन्स तयार करण्यासाठी नवीनतम वैशिष्ट्ये आणि सर्वोत्तम पद्धतींसह अद्ययावत राहणे महत्त्वाचे असेल.
@track
च्या शक्तीचा स्वीकार करा आणि LWC ची पूर्ण क्षमता अनलॉक करा!