ಸೇಲ್ಸ್ಫೋರ್ಸ್ LWC ಗಾಗಿ CSS @track ಡೆಕೋರೇಟರ್ಗೆ ಒಂದು ಸಮಗ್ರ ಮಾರ್ಗದರ್ಶಿ. ಇದು ದಕ್ಷ ಡೇಟಾ ಬದಲಾವಣೆ ಟ್ರ್ಯಾಕಿಂಗ್ ಮತ್ತು ರೆಂಡರಿಂಗ್ ಮೂಲಕ ಕಾರ್ಯಕ್ಷಮತೆ ಆಪ್ಟಿಮೈಸೇಶನ್ನಲ್ಲಿ ಅದರ ಪಾತ್ರವನ್ನು ವಿವರಿಸುತ್ತದೆ.
CSS @track: ದಕ್ಷ ಡೇಟಾ ಬೈಂಡಿಂಗ್ನೊಂದಿಗೆ ವೆಬ್ ಕಾರ್ಯಕ್ಷಮತೆಯನ್ನು ಹೆಚ್ಚಿಸುವುದು
ಆಧುನಿಕ ವೆಬ್ ಅಭಿವೃದ್ಧಿಯ ಕ್ಷೇತ್ರದಲ್ಲಿ, ವಿಶೇಷವಾಗಿ ಸೇಲ್ಸ್ಫೋರ್ಸ್ ಪರಿಸರ ವ್ಯವಸ್ಥೆಯಲ್ಲಿ ಲೈಟ್ನಿಂಗ್ ವೆಬ್ ಕಾಂಪೊನೆಂಟ್ಸ್ (LWC) ಬಳಸುವಾಗ, ಕಾರ್ಯಕ್ಷಮತೆ ಅತ್ಯಂತ ಮುಖ್ಯವಾಗಿದೆ. ಬಳಕೆದಾರರು ವೇಗವಾದ, ಸ್ಪಂದನಾಶೀಲ ಮತ್ತು ಸುಗಮ ಅನುಭವಗಳನ್ನು ನಿರೀಕ್ಷಿಸುತ್ತಾರೆ. LWCಯಲ್ಲಿ ಉತ್ತಮ ಕಾರ್ಯಕ್ಷಮತೆಯನ್ನು ಸಾಧಿಸಲು ಇರುವ ಒಂದು ಶಕ್ತಿಶಾಲಿ ಸಾಧನವೆಂದರೆ @track
ಡೆಕೋರೇಟರ್. ಈ ಲೇಖನವು ದಕ್ಷ ಡೇಟಾ ಬೈಂಡಿಂಗ್ ಮತ್ತು ಸುಧಾರಿತ ವೆಬ್ ಕಾರ್ಯಕ್ಷಮತೆಗಾಗಿ @track
ಅನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳಲು ಮತ್ತು ಬಳಸಿಕೊಳ್ಳಲು ಒಂದು ಸಮಗ್ರ ಮಾರ್ಗದರ್ಶಿಯನ್ನು ಒದಗಿಸುತ್ತದೆ.
@track
ಡೆಕೋರೇಟರ್ ಎಂದರೇನು?
LWC ಯಲ್ಲಿನ @track
ಡೆಕೋರೇಟರ್ ಅನ್ನು ಕಾಂಪೊನೆಂಟ್ನ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಕ್ಲಾಸ್ನಲ್ಲಿನ ಪ್ರಾಪರ್ಟಿಗಳ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ಬಳಸಲಾಗುತ್ತದೆ. ಒಂದು ಪ್ರಾಪರ್ಟಿಯನ್ನು @track
ನಿಂದ ಅಲಂಕರಿಸಿದಾಗ, LWCಯ ರಿಯಾಕ್ಟಿವ್ ಎಂಜಿನ್ ಆ ಪ್ರಾಪರ್ಟಿಯಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಮೇಲ್ವಿಚಾರಣೆ ಮಾಡುತ್ತದೆ. ಬದಲಾವಣೆಯನ್ನು ಪತ್ತೆಹಚ್ಚಿದಾಗ, LWC ಕಾಂಪೊನೆಂಟ್ ಅನ್ನು ಮರು-ರೆಂಡರ್ ಮಾಡುತ್ತದೆ, ಹೊಸ ಡೇಟಾವನ್ನು ಪ್ರತಿಬಿಂಬಿಸಲು ಬಳಕೆದಾರ ಇಂಟರ್ಫೇಸ್ ಅನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡುತ್ತದೆ.
ಇದನ್ನು ವಿಶೇಷ ವೀಕ್ಷಕ ಎಂದು ಭಾವಿಸಿ. ಸಂಕೀರ್ಣ ಬದಲಾವಣೆ ಪತ್ತೆ ಕಾರ್ಯವಿಧಾನಗಳನ್ನು ಹಸ್ತಚಾಲಿತವಾಗಿ ಕಾರ್ಯಗತಗೊಳಿಸುವ ಬದಲು, @track
ಯಾವ ಪ್ರಾಪರ್ಟಿಗಳು ಅಪ್ಡೇಟ್ಗಳನ್ನು ಪ್ರಚೋದಿಸಬೇಕು ಎಂದು LWC ಗೆ ಹೇಳಲು ಒಂದು ಘೋಷಣಾತ್ಮಕ ಮತ್ತು ದಕ್ಷ ಮಾರ್ಗವನ್ನು ಒದಗಿಸುತ್ತದೆ.
ಪ್ರಮುಖ ಪರಿಕಲ್ಪನೆ: @track
ಅನ್ನು ಆಯಕಟ್ಟಿನ ರೀತಿಯಲ್ಲಿ ಬಳಸುವ ಮೂಲಕ, ಯಾವ ಕಾಂಪೊನೆಂಟ್ ಅಪ್ಡೇಟ್ಗಳು ಪ್ರಚೋದಿಸಲ್ಪಡುತ್ತವೆ ಎಂಬುದನ್ನು ನೀವು ನಿಯಂತ್ರಿಸಬಹುದು, ಅನಗತ್ಯ ಮರು-ರೆಂಡರಿಂಗ್ ಅನ್ನು ಕಡಿಮೆ ಮಾಡಿ ಮತ್ತು ಕಾರ್ಯಕ್ಷಮತೆಯನ್ನು ಗಮನಾರ್ಹವಾಗಿ ಸುಧಾರಿಸಬಹುದು.
ಕಾರ್ಯಕ್ಷಮತೆಗಾಗಿ @track
ಏಕೆ ಮುಖ್ಯ?
ವೆಬ್ ಬ್ರೌಸರ್ಗಳು ನಿರಂತರವಾಗಿ ಪರದೆಯ ಮೇಲೆ ಅಂಶಗಳನ್ನು ರೆಂಡರ್ ಮತ್ತು ಮರು-ರೆಂಡರ್ ಮಾಡುತ್ತಿರುತ್ತವೆ. ಈ ಪ್ರಕ್ರಿಯೆಯು ಸಂಪನ್ಮೂಲ-ತೀವ್ರವಾಗಿರಬಹುದು, ವಿಶೇಷವಾಗಿ ಹೆಚ್ಚಿನ ಪ್ರಮಾಣದ ಡೇಟಾವನ್ನು ಹೊಂದಿರುವ ಸಂಕೀರ್ಣ ಅಪ್ಲಿಕೇಶನ್ಗಳಲ್ಲಿ. ಅನಗತ್ಯ ಮರು-ರೆಂಡರಿಂಗ್ ಇವುಗಳಿಗೆ ಕಾರಣವಾಗಬಹುದು:
- ನಿಧಾನಗತಿ: ಬಳಕೆದಾರ ಇಂಟರ್ಫೇಸ್ ನಿಧಾನ ಮತ್ತು ಸ್ಪಂದಿಸದಂತಾಗುತ್ತದೆ.
- ಹೆಚ್ಚಿದ CPU ಬಳಕೆ: ಬ್ರೌಸರ್ ಹೆಚ್ಚು ಪ್ರೊಸೆಸಿಂಗ್ ಶಕ್ತಿಯನ್ನು ಬಳಸುತ್ತದೆ, ಇದು ಮೊಬೈಲ್ ಸಾಧನಗಳಲ್ಲಿ ಬ್ಯಾಟರಿ ಬಾಳಿಕೆಯನ್ನು ಕಡಿಮೆ ಮಾಡಬಹುದು.
- ಕಳಪೆ ಬಳಕೆದಾರ ಅನುಭವ: ಬಳಕೆದಾರರು ನಿಧಾನ ಕಾರ್ಯಕ್ಷಮತೆಯಿಂದ ನಿರಾಶೆಗೊಂಡು ಅಪ್ಲಿಕೇಶನ್ ಅನ್ನು ತ್ಯಜಿಸಬಹುದು.
ಕಾಂಪೊನೆಂಟ್ಗಳು ಯಾವಾಗ ಮರು-ರೆಂಡರ್ ಆಗಬೇಕು ಎಂಬುದನ್ನು ನಿಖರವಾಗಿ ನಿಯಂತ್ರಿಸಲು ನಿಮಗೆ ಅವಕಾಶ ನೀಡುವ ಮೂಲಕ @track
ಈ ಸಮಸ್ಯೆಗಳನ್ನು ತಗ್ಗಿಸಲು ಸಹಾಯ ಮಾಡುತ್ತದೆ. @track
ಅಥವಾ ಅಂತಹುದೇ ಕಾರ್ಯವಿಧಾನಗಳಿಲ್ಲದೆ, LWC ಬದಲಾವಣೆಗಳಿಗಾಗಿ ಹೆಚ್ಚು ಆಗಾಗ್ಗೆ ಮತ್ತು ಸಂಭಾವ್ಯವಾಗಿ ಅನಗತ್ಯ ತಪಾಸಣೆಗಳನ್ನು ಮಾಡಬೇಕಾಗುತ್ತದೆ, ಇದು ಕಡಿಮೆ ಕಾರ್ಯಕ್ಷಮತೆಗೆ ಕಾರಣವಾಗುತ್ತದೆ.
@track
ಹೇಗೆ ಕೆಲಸ ಮಾಡುತ್ತದೆ?
ನೀವು ಒಂದು ಪ್ರಾಪರ್ಟಿಯನ್ನು @track
ನಿಂದ ಅಲಂಕರಿಸಿದಾಗ, LWCಯ ರಿಯಾಕ್ಟಿವ್ ಎಂಜಿನ್ ಪ್ರಾಪರ್ಟಿಯನ್ನು ಸುತ್ತುವರಿದ ಪ್ರಾಕ್ಸಿ ಆಬ್ಜೆಕ್ಟ್ ಅನ್ನು ರಚಿಸುತ್ತದೆ. ಈ ಪ್ರಾಕ್ಸಿ ಆಬ್ಜೆಕ್ಟ್ ಪ್ರಾಪರ್ಟಿಯ ಮೌಲ್ಯವನ್ನು ಮಾರ್ಪಡಿಸುವ ಯಾವುದೇ ಪ್ರಯತ್ನಗಳನ್ನು ತಡೆಯುತ್ತದೆ. ಮಾರ್ಪಾಡು ಪತ್ತೆಯಾದಾಗ, ಪ್ರಾಕ್ಸಿ ಆಬ್ಜೆಕ್ಟ್ ಕಾಂಪೊನೆಂಟ್ನ ಮರು-ರೆಂಡರಿಂಗ್ ಅನ್ನು ಪ್ರಚೋದಿಸುತ್ತದೆ.
ಪ್ರಮುಖ ಪರಿಗಣನೆ: @track
ಪ್ರಾಪರ್ಟಿಯ *ಮೌಲ್ಯ*ದಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಮಾತ್ರ ಟ್ರ್ಯಾಕ್ ಮಾಡುತ್ತದೆ, ಪ್ರಾಪರ್ಟಿ ಒಂದು ಆಬ್ಜೆಕ್ಟ್ ಅಥವಾ ಅರೇ ಆಗಿದ್ದರೆ ಅದರ *ಒಳಗಿನ* ಬದಲಾವಣೆಗಳನ್ನಲ್ಲ. @track
ಅನ್ನು ಪರಿಣಾಮಕಾರಿಯಾಗಿ ಹೇಗೆ ಬಳಸುವುದು ಎಂಬುದನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳಲು ಇದು ಒಂದು ನಿರ್ಣಾಯಕ ವ್ಯತ್ಯಾಸವಾಗಿದೆ.
@track
vs. ಪಬ್ಲಿಕ್ ಪ್ರಾಪರ್ಟೀಸ್ (@api
)
@track
ಅನ್ನು @api
ನಿಂದ ಅಲಂಕರಿಸಿದ ಪಬ್ಲಿಕ್ ಪ್ರಾಪರ್ಟಿಗಳಿಂದ ಪ್ರತ್ಯೇಕಿಸುವುದು ಮುಖ್ಯ. ಎರಡೂ ಮರು-ರೆಂಡರಿಂಗ್ ಅನ್ನು ಪ್ರಚೋದಿಸಬಹುದಾದರೂ, ಅವು ವಿಭಿನ್ನ ಉದ್ದೇಶಗಳನ್ನು ಪೂರೈಸುತ್ತವೆ:
@track
: ಕಾಂಪೊನೆಂಟ್ನೊಳಗಿನ ಖಾಸಗಿ ಪ್ರಾಪರ್ಟಿಗಳ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ಬಳಸಲಾಗುತ್ತದೆ. ಈ ಪ್ರಾಪರ್ಟಿಗಳಲ್ಲಿನ ಬದಲಾವಣೆಗಳು ಸಾಮಾನ್ಯವಾಗಿ ಕಾಂಪೊನೆಂಟ್ನಿಂದಲೇ ಪ್ರಾರಂಭವಾಗುತ್ತವೆ.@api
: ಪೇರೆಂಟ್ ಕಾಂಪೊನೆಂಟ್ಗಳು ಅಥವಾ ಬಾಹ್ಯ ಸಿಸ್ಟಮ್ಗಳಿಂದ (ಉದಾಹರಣೆಗೆ, ಅಪೆಕ್ಸ್ ಅಥವಾ ಇತರ ಲೈಟ್ನಿಂಗ್ ಕಾಂಪೊನೆಂಟ್ಗಳಿಂದ) ಪ್ರವೇಶಿಸಬಹುದಾದ ಮತ್ತು ಮಾರ್ಪಡಿಸಬಹುದಾದ ಸಾರ್ವಜನಿಕ ಪ್ರಾಪರ್ಟಿಗಳನ್ನು ವ್ಯಾಖ್ಯಾನಿಸಲು ಬಳಸಲಾಗುತ್ತದೆ.
@api
ಪ್ರಾಪರ್ಟಿಗಳಲ್ಲಿನ ಬದಲಾವಣೆಗಳು *ಯಾವಾಗಲೂ* ಮರು-ರೆಂಡರ್ ಅನ್ನು ಪ್ರಚೋದಿಸುತ್ತವೆ, ಏಕೆಂದರೆ ಅವು ಕಾಂಪೊನೆಂಟ್ನ ಸಾರ್ವಜನಿಕ ಇಂಟರ್ಫೇಸ್ ಅನ್ನು ಪ್ರತಿನಿಧಿಸುತ್ತವೆ. @track
ಆಂತರಿಕ ಕಾಂಪೊನೆಂಟ್ ಸ್ಟೇಟ್ಗಾಗಿ ಮರು-ರೆಂಡರಿಂಗ್ ಮೇಲೆ ನಿಮಗೆ ಹೆಚ್ಚು ಸೂಕ್ಷ್ಮ-ನಿಯಂತ್ರಿತ ನಿಯಂತ್ರಣವನ್ನು ನೀಡುತ್ತದೆ.
@track
ಅನ್ನು ಯಾವಾಗ ಬಳಸಬೇಕು
@track
ಅನ್ನು ಬಳಸುವುದು ಪ್ರಯೋಜನಕಾರಿಯಾದ ಕೆಲವು ಸಾಮಾನ್ಯ ಸನ್ನಿವೇಶಗಳು ಇಲ್ಲಿವೆ:
- ಪ್ರಿಮಿಟಿವ್ ಡೇಟಾ ಪ್ರಕಾರಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದು: ಸ್ಟ್ರಿಂಗ್ಗಳು, ಸಂಖ್ಯೆಗಳು, ಬೂಲಿಯನ್ಗಳು ಮತ್ತು ದಿನಾಂಕಗಳಂತಹ ಸರಳ ಡೇಟಾ ಪ್ರಕಾರಗಳಿಗಾಗಿ
@track
ಬಳಸಿ. ಈ ಪ್ರಕಾರಗಳಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ನೇರವಾಗಿ ಟ್ರ್ಯಾಕ್ ಮಾಡಲಾಗುತ್ತದೆ ಮತ್ತು ಮರು-ರೆಂಡರ್ ಅನ್ನು ಪ್ರಚೋದಿಸುತ್ತದೆ. - ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದು (ಭಾಗಶಃ):
@track
ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳ *ಒಳಗಿನ* ಬದಲಾವಣೆಗಳನ್ನು ಆಳವಾಗಿ ಟ್ರ್ಯಾಕ್ ಮಾಡದಿದ್ದರೂ, ಅದು ಆಬ್ಜೆಕ್ಟ್ ಅಥವಾ ಅರೇ *ರೆಫರೆನ್ಸ್* ನಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುತ್ತದೆ. ಇದರರ್ಥ ನೀವು@track
ಅಲಂಕರಿಸಿದ ಪ್ರಾಪರ್ಟಿಗೆ ಹೊಸ ಆಬ್ಜೆಕ್ಟ್ ಅಥವಾ ಅರೇಯನ್ನು ನಿಯೋಜಿಸಿದರೆ, ಅದು ಮರು-ರೆಂಡರ್ ಅನ್ನು *ಪ್ರಚೋದಿಸುತ್ತದೆ*. - ಬಳಕೆದಾರರ ಸಂವಹನದ ಆಧಾರದ ಮೇಲೆ ರೆಂಡರಿಂಗ್ ಅನ್ನು ಆಪ್ಟಿಮೈಜ್ ಮಾಡುವುದು: ಬಳಕೆದಾರರ ಕ್ರಿಯೆಗಳ (ಉದಾಹರಣೆಗೆ, ಬಟನ್ ಕ್ಲಿಕ್ಗಳು, ಇನ್ಪುಟ್ ಬದಲಾವಣೆಗಳು) ಆಧಾರದ ಮೇಲೆ ಅಪ್ಡೇಟ್ ಆಗುವ ಕಾಂಪೊನೆಂಟ್ ಅನ್ನು ನೀವು ಹೊಂದಿದ್ದರೆ, ಸಂಬಂಧಿತ ಡೇಟಾ ಬದಲಾದಾಗ ಮಾತ್ರ ಕಾಂಪೊನೆಂಟ್ ಮರು-ರೆಂಡರ್ ಆಗುವುದನ್ನು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು
@track
ಬಳಸಿ.
@track
ಅನ್ನು ಯಾವಾಗ ಬಳಸಬಾರದು (ಮತ್ತು ಪರ್ಯಾಯಗಳು)
ಕೆಲವು ಸಂದರ್ಭಗಳಲ್ಲಿ @track
ಅತ್ಯಂತ ಸೂಕ್ತ ಆಯ್ಕೆಯಾಗಿರದಿರಬಹುದು, ವಿಶೇಷವಾಗಿ ಸಂಕೀರ್ಣ ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳೊಂದಿಗೆ ವ್ಯವಹರಿಸುವಾಗ. ಇದನ್ನು ತಪ್ಪಾಗಿ ಬಳಸುವುದರಿಂದ ಅನಿರೀಕ್ಷಿತ ನಡವಳಿಕೆ ಅಥವಾ ಕಾರ್ಯಕ್ಷಮತೆಯ ಸಮಸ್ಯೆಗಳಿಗೆ ಕಾರಣವಾಗಬಹುದು.
- ಆಳವಾಗಿ ನೆಸ್ಟೆಡ್ ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳು: ಮೊದಲೇ ಹೇಳಿದಂತೆ,
@track
ಆಬ್ಜೆಕ್ಟ್ ಅಥವಾ ಅರೇಯ *ರೆಫರೆನ್ಸ್* ನಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಮಾತ್ರ ಟ್ರ್ಯಾಕ್ ಮಾಡುತ್ತದೆ, ಅದರ *ಒಳಗಿನ* ಬದಲಾವಣೆಗಳನ್ನಲ್ಲ. ನೀವು ನೆಸ್ಟೆಡ್ ಆಬ್ಜೆಕ್ಟ್ ಅಥವಾ ಅರೇಯ ಆಳದಲ್ಲಿರುವ ಪ್ರಾಪರ್ಟಿಯನ್ನು ಮಾರ್ಪಡಿಸಿದರೆ, ಕಾಂಪೊನೆಂಟ್ ಮರು-ರೆಂಡರ್ *ಆಗುವುದಿಲ್ಲ*. - ದೊಡ್ಡ ಡೇಟಾಸೆಟ್ಗಳು: ಅತಿ ದೊಡ್ಡ ಡೇಟಾಸೆಟ್ಗಳೊಂದಿಗೆ ವ್ಯವಹರಿಸುವಾಗ,
@track
ನೊಂದಿಗೆ ಪ್ರತಿಯೊಂದು ಬದಲಾವಣೆಯನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದು ಅದಕ್ಷವಾಗಬಹುದು. ಪೇಜಿನೇಷನ್, ವರ್ಚುವಲೈಸೇಶನ್, ಅಥವಾ ವಿಶೇಷ ಡೇಟಾ ರಚನೆಗಳನ್ನು ಬಳಸುವಂತಹ ಪರ್ಯಾಯ ತಂತ್ರಗಳನ್ನು ಪರಿಗಣಿಸಿ.
ಸಂಕೀರ್ಣ ಡೇಟಾಕ್ಕಾಗಿ @track
ಗೆ ಪರ್ಯಾಯಗಳು:
- ಇಮ್ಮ್ಯೂಟಬಿಲಿಟಿ ( ಬದಲಾಯಿಸಲಾಗದಿರುವಿಕೆ): ನಿಮ್ಮ ಡೇಟಾವನ್ನು ಬದಲಾಯಿಸಲಾಗದು ಎಂದು ಪರಿಗಣಿಸಿ. ಅಸ್ತಿತ್ವದಲ್ಲಿರುವ ಆಬ್ಜೆಕ್ಟ್ಗಳು ಅಥವಾ ಅರೇಗಳನ್ನು ಮಾರ್ಪಡಿಸುವ ಬದಲು, ಬಯಸಿದ ಬದಲಾವಣೆಗಳೊಂದಿಗೆ ಹೊಸದನ್ನು ರಚಿಸಿ. ಇದು ಆಬ್ಜೆಕ್ಟ್ ರೆಫರೆನ್ಸ್ ಬದಲಾಗುವುದನ್ನು ಖಚಿತಪಡಿಸುತ್ತದೆ,
@track
ಪ್ರಾಪರ್ಟಿ ಅಪ್ಡೇಟ್ ಆದಾಗ ಮರು-ರೆಂಡರ್ ಅನ್ನು ಪ್ರಚೋದಿಸುತ್ತದೆ. Immer.js ನಂತಹ ಲೈಬ್ರರಿಗಳು ಬದಲಾಯಿಸಲಾಗದ ಡೇಟಾ ನಿರ್ವಹಣೆಗೆ ಸಹಾಯ ಮಾಡಬಹುದು. - ಹಸ್ತಚಾಲಿತ ಮರು-ರೆಂಡರಿಂಗ್: ಕೆಲವು ಸಂದರ್ಭಗಳಲ್ಲಿ, ನೀವು
renderedCallback()
ಲೈಫ್ಸೈಕಲ್ ಹುಕ್ ಬಳಸಿ ಹಸ್ತಚಾಲಿತವಾಗಿ ಮರು-ರೆಂಡರ್ ಅನ್ನು ಪ್ರಚೋದಿಸಬೇಕಾಗಬಹುದು. ಇದು ನಿಮಗೆ ರೆಂಡರಿಂಗ್ ಪ್ರಕ್ರಿಯೆಯ ಮೇಲೆ ಸಂಪೂರ್ಣ ನಿಯಂತ್ರಣವನ್ನು ನೀಡುತ್ತದೆ. ಆದಾಗ್ಯೂ, ಇದನ್ನು ಮಿತವಾಗಿ ಬಳಸಿ, ಏಕೆಂದರೆ ಇದು ನಿಮ್ಮ ಕೋಡ್ ಅನ್ನು ಹೆಚ್ಚು ಸಂಕೀರ್ಣಗೊಳಿಸಬಹುದು. - ಈವೆಂಟ್ ಹ್ಯಾಂಡ್ಲಿಂಗ್ ಮತ್ತು ಉದ್ದೇಶಿತ ಅಪ್ಡೇಟ್ಗಳು: ಪ್ರತಿ ಬದಲಾವಣೆಯನ್ನು ಪತ್ತೆಹಚ್ಚಲು
@track
ಮೇಲೆ ಅವಲಂಬಿತರಾಗುವ ಬದಲು, ಕಾಂಪೊನೆಂಟ್ನ ನಿರ್ದಿಷ್ಟ ಭಾಗಗಳನ್ನು ನೇರವಾಗಿ ಅಪ್ಡೇಟ್ ಮಾಡಲು ಈವೆಂಟ್ ಹ್ಯಾಂಡ್ಲಿಂಗ್ ಅನ್ನು ಬಳಸುವುದನ್ನು ಪರಿಗಣಿಸಿ. ಉದಾಹರಣೆಗೆ, ಬಳಕೆದಾರರು ಪಟ್ಟಿಯಲ್ಲಿ ಒಂದೇ ಐಟಂ ಅನ್ನು ಎಡಿಟ್ ಮಾಡಿದರೆ, ಸಂಪೂರ್ಣ ಪಟ್ಟಿಯನ್ನು ಮರು-ರೆಂಡರ್ ಮಾಡುವ ಬದಲು ಆ ಐಟಂನ ದೃಶ್ಯ ಪ್ರಾತಿನಿಧ್ಯವನ್ನು ಮಾತ್ರ ಅಪ್ಡೇಟ್ ಮಾಡಿ.
@track
ಬಳಸುವ ಪ್ರಾಯೋಗಿಕ ಉದಾಹರಣೆಗಳು
ಕೆಲವು ಪ್ರಾಯೋಗಿಕ ಉದಾಹರಣೆಗಳೊಂದಿಗೆ @track
ಬಳಕೆಯನ್ನು ವಿವರಿಸೋಣ.
ಉದಾಹರಣೆ 1: ಸರಳ ಕೌಂಟರ್ ಅನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದು
ಈ ಉದಾಹರಣೆಯು ಬಟನ್ ಕ್ಲಿಕ್ ಮಾಡಿದಾಗ ಹೆಚ್ಚಾಗುವ ಸರಳ ಕೌಂಟರ್ ಅನ್ನು ಹೇಗೆ ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದು ಎಂಬುದನ್ನು ತೋರಿಸುತ್ತದೆ.
ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ (myComponent.js):
import { LightningElement, track } from 'lwc';
export default class MyComponent extends LightningElement {
@track counter = 0;
incrementCounter() {
this.counter++;
}
}
HTML (myComponent.html):
Counter: {counter}
ಈ ಉದಾಹರಣೆಯಲ್ಲಿ, counter
ಪ್ರಾಪರ್ಟಿಯನ್ನು @track
ನಿಂದ ಅಲಂಕರಿಸಲಾಗಿದೆ. incrementCounter()
ಮೆಥಡ್ ಅನ್ನು ಕರೆದಾಗ, counter
ನ ಮೌಲ್ಯವು ಹೆಚ್ಚಾಗುತ್ತದೆ, ಇದು ಕಾಂಪೊನೆಂಟ್ನ ಮರು-ರೆಂಡರಿಂಗ್ ಅನ್ನು ಪ್ರಚೋದಿಸುತ್ತದೆ ಮತ್ತು ಪ್ರದರ್ಶಿಸಲಾದ ಕೌಂಟರ್ ಮೌಲ್ಯವನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡುತ್ತದೆ.
ಉದಾಹರಣೆ 2: ಆಬ್ಜೆಕ್ಟ್ನಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದು (ಶಾಲೋ ಟ್ರ್ಯಾಕಿಂಗ್)
ಈ ಉದಾಹರಣೆಯು @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'
};
}
}
HTML (myComponent.html):
First Name: {contact.firstName}
Last Name: {contact.lastName}
"Update First Name" ಬಟನ್ ಕ್ಲಿಕ್ ಮಾಡುವುದರಿಂದ ಕಾಂಪೊನೆಂಟ್ ಮರು-ರೆಂಡರ್ ಆಗುವುದಿಲ್ಲ ಏಕೆಂದರೆ @track
ಆಬ್ಜೆಕ್ಟ್ *ರೆಫರೆನ್ಸ್* ನಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಮಾತ್ರ ಟ್ರ್ಯಾಕ್ ಮಾಡುತ್ತದೆ, ಆಬ್ಜೆಕ್ಟ್ *ಒಳಗಿನ* ಬದಲಾವಣೆಗಳನ್ನಲ್ಲ. "Replace Contact" ಬಟನ್ ಕ್ಲಿಕ್ ಮಾಡುವುದರಿಂದ ಮರು-ರೆಂಡರ್ ಉಂಟಾಗುತ್ತದೆ ಏಕೆಂದರೆ ಅದು contact
ಪ್ರಾಪರ್ಟಿಗೆ ಹೊಸ ಆಬ್ಜೆಕ್ಟ್ ಅನ್ನು ನಿಯೋಜಿಸುತ್ತದೆ.
ಉದಾಹರಣೆ 3: ಆಬ್ಜೆಕ್ಟ್ನಲ್ಲಿನ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ಇಮ್ಮ್ಯೂಟಬಿಲಿಟಿ ಬಳಸುವುದು (ಡೀಪ್ ಟ್ರ್ಯಾಕಿಂಗ್)
ಈ ಉದಾಹರಣೆಯು @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'
};
}
}
HTML (myComponent.html):
First Name: {contact.firstName}
Last Name: {contact.lastName}
ಈ ಉದಾಹರಣೆಯಲ್ಲಿ, updateFirstName()
ಮೆಥಡ್ ಸ್ಪ್ರೆಡ್ ಆಪರೇಟರ್ (...
) ಬಳಸಿ ಅಪ್ಡೇಟ್ ಮಾಡಿದ firstName
ನೊಂದಿಗೆ *ಹೊಸ* ಆಬ್ಜೆಕ್ಟ್ ಅನ್ನು ರಚಿಸುತ್ತದೆ. ಇದು contact
ಪ್ರಾಪರ್ಟಿ ಅಪ್ಡೇಟ್ ಆದಾಗ ಆಬ್ಜೆಕ್ಟ್ ರೆಫರೆನ್ಸ್ ಬದಲಾಗುವುದನ್ನು ಮತ್ತು ಮರು-ರೆಂಡರ್ ಪ್ರಚೋದಿಸುವುದನ್ನು ಖಚಿತಪಡಿಸುತ್ತದೆ.
@track
ಬಳಸಲು ಉತ್ತಮ ಅಭ್ಯಾಸಗಳು
@track
ನ ಪ್ರಯೋಜನಗಳನ್ನು ಗರಿಷ್ಠಗೊಳಿಸಲು ಮತ್ತು ಸಂಭಾವ್ಯ ಕಾರ್ಯಕ್ಷಮತೆಯ ಅಪಾಯಗಳನ್ನು ತಪ್ಪಿಸಲು, ಈ ಉತ್ತಮ ಅಭ್ಯಾಸಗಳನ್ನು ಅನುಸರಿಸಿ:
@track
ಅನ್ನು ಮಿತವಾಗಿ ಬಳಸಿ: ಮರು-ರೆಂಡರಿಂಗ್ ಅನ್ನು ಪ್ರಚೋದಿಸಬೇಕಾದ ಪ್ರಾಪರ್ಟಿಗಳನ್ನು ಮಾತ್ರ ಅಲಂಕರಿಸಿ. ಆಂತರಿಕ ಲೆಕ್ಕಾಚಾರಗಳಿಗೆ ಅಥವಾ ತಾತ್ಕಾಲಿಕ ಸಂಗ್ರಹಣೆಗಾಗಿ ಮಾತ್ರ ಬಳಸುವ ಪ್ರಾಪರ್ಟಿಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡುವುದನ್ನು ತಪ್ಪಿಸಿ.- ಇಮ್ಮ್ಯೂಟಬಿಲಿಟಿಗೆ ಆದ್ಯತೆ ನೀಡಿ: ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳೊಂದಿಗೆ ಕೆಲಸ ಮಾಡುವಾಗ, ಬದಲಾವಣೆಗಳನ್ನು ಸರಿಯಾಗಿ ಟ್ರ್ಯಾಕ್ ಮಾಡಲಾಗಿದೆಯೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ಇಮ್ಮ್ಯೂಟಬಿಲಿಟಿಗೆ ಆದ್ಯತೆ ನೀಡಿ. ಅಸ್ತಿತ್ವದಲ್ಲಿರುವ ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳನ್ನು ಮಾರ್ಪಡಿಸುವ ಬದಲು ಹೊಸದನ್ನು ರಚಿಸಲು ಸ್ಪ್ರೆಡ್ ಆಪರೇಟರ್ ಅಥವಾ Immer.js ನಂತಹ ಲೈಬ್ರರಿಗಳಂತಹ ತಂತ್ರಗಳನ್ನು ಬಳಸಿ.
- ಕಾಂಪೊನೆಂಟ್ ಶ್ರೇಣಿಯನ್ನು ಪರಿಗಣಿಸಿ: ಒಂದು ಕಾಂಪೊನೆಂಟ್ನಲ್ಲಿನ ಬದಲಾವಣೆಗಳು ಶ್ರೇಣಿಯಲ್ಲಿನ ಇತರ ಕಾಂಪೊನೆಂಟ್ಗಳ ಮೇಲೆ ಹೇಗೆ ಪರಿಣಾಮ ಬೀರಬಹುದು ಎಂಬುದರ ಬಗ್ಗೆ ಯೋಚಿಸಿ. ಕಾಂಪೊನೆಂಟ್ಗಳ ನಡುವೆ ಬದಲಾವಣೆಗಳನ್ನು ಸಂವಹನ ಮಾಡಲು ಈವೆಂಟ್ಗಳನ್ನು ಬಳಸಿ ಮತ್ತು ಪೇರೆಂಟ್ ಕಾಂಪೊನೆಂಟ್ಗಳ ಅನಗತ್ಯ ಮರು-ರೆಂಡರಿಂಗ್ ಅನ್ನು ತಪ್ಪಿಸಿ.
- ನಿಮ್ಮ ಕಾಂಪೊನೆಂಟ್ಗಳನ್ನು ಪ್ರೊಫೈಲ್ ಮಾಡಿ: ನಿಮ್ಮ ಕಾಂಪೊನೆಂಟ್ಗಳನ್ನು ಪ್ರೊಫೈಲ್ ಮಾಡಲು ಮತ್ತು ಕಾರ್ಯಕ್ಷಮತೆಯ ಅಡಚಣೆಗಳನ್ನು ಗುರುತಿಸಲು ಸೇಲ್ಸ್ಫೋರ್ಸ್ ಲೈಟ್ನಿಂಗ್ ಇನ್ಸ್ಪೆಕ್ಟರ್ ಬಳಸಿ.
@track
ಅನ್ನು ಅದಕ್ಷವಾಗಿ ಬಳಸಲಾಗುತ್ತಿರುವ ಅಥವಾ ಪರ್ಯಾಯ ಆಪ್ಟಿಮೈಸೇಶನ್ ತಂತ್ರಗಳು ಹೆಚ್ಚು ಸೂಕ್ತವಾಗಬಹುದಾದ ಪ್ರದೇಶಗಳನ್ನು ಗುರುತಿಸಲು ಇದು ನಿಮಗೆ ಸಹಾಯ ಮಾಡುತ್ತದೆ. - ಸಂಪೂರ್ಣವಾಗಿ ಪರೀಕ್ಷಿಸಿ: ನಿಮ್ಮ ಕಾಂಪೊನೆಂಟ್ಗಳು ಸರಿಯಾಗಿ ಮರು-ರೆಂಡರ್ ಆಗುತ್ತಿವೆಯೇ ಮತ್ತು ಬಳಕೆದಾರ ಇಂಟರ್ಫೇಸ್ ನಿರೀಕ್ಷೆಯಂತೆ ಅಪ್ಡೇಟ್ ಆಗುತ್ತಿದೆಯೇ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ಅವುಗಳನ್ನು ಸಂಪೂರ್ಣವಾಗಿ ಪರೀಕ್ಷಿಸಿ. ವಿಶೇಷವಾಗಿ ಎಡ್ಜ್ ಕೇಸ್ಗಳು ಮತ್ತು ಸಂಕೀರ್ಣ ಡೇಟಾ ಸನ್ನಿವೇಶಗಳಿಗೆ ಗಮನ ಕೊಡಿ.
ನೈಜ-ಪ್ರಪಂಚದ ಸನ್ನಿವೇಶಗಳಲ್ಲಿ @track
ನೈಜ-ಪ್ರಪಂಚದ ಸೇಲ್ಸ್ಫೋರ್ಸ್ LWC ಸನ್ನಿವೇಶಗಳಲ್ಲಿ @track
ಅನ್ನು ಹೇಗೆ ಬಳಸಬಹುದು ಎಂಬುದನ್ನು ಅನ್ವೇಷಿಸೋಣ.
- ಡೈನಾಮಿಕ್ ಫಾರ್ಮ್ಗಳು: ಡೈನಾಮಿಕ್ ಫಾರ್ಮ್ ಕಾಂಪೊನೆಂಟ್ನಲ್ಲಿ, ಫಾರ್ಮ್ ಫೀಲ್ಡ್ಗಳ ಮೌಲ್ಯಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ನೀವು
@track
ಅನ್ನು ಬಳಸಬಹುದು. ಬಳಕೆದಾರರು ಫೀಲ್ಡ್ ಮೌಲ್ಯವನ್ನು ಬದಲಾಯಿಸಿದಾಗ, ಇತರ ಫೀಲ್ಡ್ಗಳ ಪ್ರದರ್ಶನವನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡಲು ಅಥವಾ ವ್ಯಾಲಿಡೇಶನ್ಗಳನ್ನು ಮಾಡಲು ಕಾಂಪೊನೆಂಟ್ ಮರು-ರೆಂಡರ್ ಆಗುತ್ತದೆ. ಉದಾಹರಣೆಗೆ, "ದೇಶ" ಫೀಲ್ಡ್ ಅನ್ನು ಬದಲಾಯಿಸುವುದರಿಂದ "ರಾಜ್ಯ/ಪ್ರಾಂತ್ಯ" ಫೀಲ್ಡ್ನಲ್ಲಿ ಲಭ್ಯವಿರುವ ಆಯ್ಕೆಗಳನ್ನು ಡೈನಾಮಿಕ್ ಆಗಿ ಅಪ್ಡೇಟ್ ಮಾಡಬಹುದು. ಪ್ರಾಂತ್ಯಗಳನ್ನು ಹೊಂದಿರುವ ಕೆನಡಾ ಮತ್ತು ರಾಜ್ಯಗಳನ್ನು ಹೊಂದಿರುವ ಯುನೈಟೆಡ್ ಸ್ಟೇಟ್ಸ್ ನಂತಹ ದೇಶಗಳನ್ನು ಪರಿಗಣಿಸಿ; ಪ್ರದರ್ಶಿಸಲಾದ ಆಯ್ಕೆಗಳು ಸಂದರ್ಭೋಚಿತವಾಗಿ ಸಂಬಂಧಿತವಾಗಿರಬೇಕು. - ಸಂವಾದಾತ್ಮಕ ಚಾರ್ಟ್ಗಳು ಮತ್ತು ಗ್ರಾಫ್ಗಳು: ನೀವು LWC ಯಲ್ಲಿ ಸಂವಾದಾತ್ಮಕ ಚಾರ್ಟ್ಗಳು ಅಥವಾ ಗ್ರಾಫ್ಗಳನ್ನು ನಿರ್ಮಿಸುತ್ತಿದ್ದರೆ, ಆಯ್ಕೆಮಾಡಿದ ಡೇಟಾ ಪಾಯಿಂಟ್ಗಳು ಅಥವಾ ಫಿಲ್ಟರ್ ಮಾನದಂಡಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ನೀವು
@track
ಅನ್ನು ಬಳಸಬಹುದು. ಬಳಕೆದಾರರು ಚಾರ್ಟ್ನೊಂದಿಗೆ ಸಂವಹನ ನಡೆಸಿದಾಗ (ಉದಾಹರಣೆಗೆ, ಬಾರ್ ಮೇಲೆ ಕ್ಲಿಕ್ ಮಾಡುವ ಮೂಲಕ), ಚಾರ್ಟ್ನ ಪ್ರದರ್ಶನವನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡಲು ಅಥವಾ ಆಯ್ಕೆಮಾಡಿದ ಡೇಟಾ ಪಾಯಿಂಟ್ ಬಗ್ಗೆ ವಿವರವಾದ ಮಾಹಿತಿಯನ್ನು ತೋರಿಸಲು ಕಾಂಪೊನೆಂಟ್ ಮರು-ರೆಂಡರ್ ಆಗುತ್ತದೆ. ಉತ್ತರ ಅಮೇರಿಕಾ, ಯುರೋಪ್, ಏಷ್ಯಾ-ಪೆಸಿಫಿಕ್ ನಂತಹ ವಿವಿಧ ಪ್ರದೇಶಗಳ ಡೇಟಾವನ್ನು ಪ್ರದರ್ಶಿಸುವ ಸೇಲ್ಸ್ ಡ್ಯಾಶ್ಬೋರ್ಡ್ ಅನ್ನು ಕಲ್ಪಿಸಿಕೊಳ್ಳಿ. ಒಂದು ಪ್ರದೇಶವನ್ನು ಆಯ್ಕೆ ಮಾಡುವುದರಿಂದ ಆ ಪ್ರದೇಶದೊಳಗಿನ ಮಾರಾಟದ ಕಾರ್ಯಕ್ಷಮತೆಯ ಹೆಚ್ಚು ವಿವರವಾದ ನೋಟವನ್ನು ತೋರಿಸಲು ಚಾರ್ಟ್ ಅಪ್ಡೇಟ್ ಆಗುತ್ತದೆ. - ನೈಜ-ಸಮಯದ ಡೇಟಾ ಅಪ್ಡೇಟ್ಗಳು: ನೈಜ-ಸಮಯದ ಡೇಟಾ ಅಪ್ಡೇಟ್ಗಳು ಅಗತ್ಯವಿರುವ ಅಪ್ಲಿಕೇಶನ್ಗಳಲ್ಲಿ (ಉದಾ., ಸ್ಟಾಕ್ ಟಿಕ್ಕರ್ಗಳು, ಸೆನ್ಸರ್ ರೀಡಿಂಗ್ಸ್), ಒಳಬರುವ ಡೇಟಾವನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ಮತ್ತು ಅದಕ್ಕೆ ಅನುಗುಣವಾಗಿ ಬಳಕೆದಾರ ಇಂಟರ್ಫೇಸ್ ಅನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡಲು ನೀವು
@track
ಅನ್ನು ಬಳಸಬಹುದು. ಡೇಟಾ ಪ್ರಮಾಣ ಮತ್ತು ಅಪ್ಡೇಟ್ ಆವರ್ತನವನ್ನು ಪರಿಗಣಿಸಿ ಬಳಸಿ; ಅತ್ಯಂತ ಹೆಚ್ಚಿನ-ಆವರ್ತನದ ಅಪ್ಡೇಟ್ಗಳಿಗಾಗಿ ಪರ್ಯಾಯ ವಿಧಾನಗಳು ಬೇಕಾಗಬಹುದು. ಉದಾಹರಣೆಗೆ, USD, EUR, JPY, ಮತ್ತು GBP ನಡುವಿನ ನೈಜ-ಸಮಯದ ವಿನಿಮಯ ದರಗಳನ್ನು ಪ್ರದರ್ಶಿಸುವ ಕಾಂಪೊನೆಂಟ್ ದರಗಳು ಬದಲಾದಂತೆ ಅವುಗಳನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡಲು@track
ಅನ್ನು ಬಳಸುತ್ತದೆ. - ಕಸ್ಟಮ್ ಹುಡುಕಾಟ ಕಾಂಪೊನೆಂಟ್ಗಳು: ಕಸ್ಟಮ್ ಹುಡುಕಾಟ ಕಾಂಪೊನೆಂಟ್ ಅನ್ನು ನಿರ್ಮಿಸುವಾಗ, ಹುಡುಕಾಟ ಪದ ಮತ್ತು ಹುಡುಕಾಟ ಫಲಿತಾಂಶಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು
@track
ಅನ್ನು ಬಳಸಬಹುದು. ಬಳಕೆದಾರರು ಹುಡುಕಾಟ ಬಾಕ್ಸ್ನಲ್ಲಿ ಟೈಪ್ ಮಾಡಿದಂತೆ, ಹುಡುಕಾಟ ಫಲಿತಾಂಶಗಳನ್ನು ಅಪ್ಡೇಟ್ ಮಾಡಲು ಕಾಂಪೊನೆಂಟ್ ಮರು-ರೆಂಡರ್ ಆಗುತ್ತದೆ. ಹುಡುಕಾಟವು ಪ್ರದರ್ಶಿಸಲಾದ ಡೇಟಾಗೆ ಫಿಲ್ಟರ್ಗಳು ಮತ್ತು ಸಾರ್ಟ್ಗಳನ್ನು ಅನ್ವಯಿಸಿದರೆ ಇದು ವಿಶೇಷವಾಗಿ ಉಪಯುಕ್ತವಾಗಿದೆ. ವಿವಿಧ ಮೂಲಗಳಿಂದ ಡೇಟಾವನ್ನು ಹಿಂಪಡೆಯುವ ಜಾಗತಿಕ ಹುಡುಕಾಟ ಕಾಂಪೊನೆಂಟ್ ಅನ್ನು ಪರಿಗಣಿಸಿ;@track
ಬಳಸುವುದರಿಂದ ಬಳಕೆದಾರರ ಇನ್ಪುಟ್ ಆಧಾರದ ಮೇಲೆ ಹುಡುಕಾಟದ ನೈಜ-ಸಮಯದ ಪರಿಷ್ಕರಣೆ ಸಾಧ್ಯವಾಗುತ್ತದೆ.
LWC ಯಲ್ಲಿ @track
ಮತ್ತು ರಿಯಾಕ್ಟಿವ್ ಪ್ರೋಗ್ರಾಮಿಂಗ್ನ ಭವಿಷ್ಯ
@track
ಡೆಕೋರೇಟರ್ LWC ಯ ರಿಯಾಕ್ಟಿವ್ ಪ್ರೋಗ್ರಾಮಿಂಗ್ ಮಾದರಿಯ ಒಂದು ಮೂಲಭೂತ ಭಾಗವಾಗಿದೆ. LWC ವಿಕಸನಗೊಳ್ಳುತ್ತಾ ಹೋದಂತೆ, ರಿಯಾಕ್ಟಿವ್ ಎಂಜಿನ್ಗೆ ಮತ್ತಷ್ಟು ವರ್ಧನೆಗಳನ್ನು ಮತ್ತು ಉನ್ನತ-ಕಾರ್ಯಕ್ಷಮತೆಯ ವೆಬ್ ಅಪ್ಲಿಕೇಶನ್ಗಳನ್ನು ನಿರ್ಮಿಸುವುದನ್ನು ಇನ್ನಷ್ಟು ಸುಲಭಗೊಳಿಸುವ ಹೊಸ ವೈಶಿಷ್ಟ್ಯಗಳನ್ನು ನಾವು ನಿರೀಕ್ಷಿಸಬಹುದು.
ಸಂಭಾವ್ಯ ಭವಿಷ್ಯದ ದಿಕ್ಕುಗಳು:
- ಸುಧಾರಿತ ಡೀಪ್ ಟ್ರ್ಯಾಕಿಂಗ್: LWC ಯ ಭವಿಷ್ಯದ ಆವೃತ್ತಿಗಳು ಆಬ್ಜೆಕ್ಟ್ಗಳು ಮತ್ತು ಅರೇಗಳೊಳಗಿನ ಬದಲಾವಣೆಗಳನ್ನು ಟ್ರ್ಯಾಕ್ ಮಾಡಲು ಹೆಚ್ಚು ದೃಢವಾದ ಕಾರ್ಯವಿಧಾನಗಳನ್ನು ಒದಗಿಸಬಹುದು, ಹಸ್ತಚಾಲಿತ ಇಮ್ಮ್ಯೂಟಬಿಲಿಟಿ ನಿರ್ವಹಣೆಯ ಅಗತ್ಯವನ್ನು ಕಡಿಮೆ ಮಾಡಬಹುದು.
- ಮರು-ರೆಂಡರಿಂಗ್ ಮೇಲೆ ಹೆಚ್ಚು ಸೂಕ್ಷ್ಮ ನಿಯಂತ್ರಣ: LWC ಹೊಸ ವೈಶಿಷ್ಟ್ಯಗಳನ್ನು ಪರಿಚಯಿಸಬಹುದು, ಅದು ಡೆವಲಪರ್ಗಳಿಗೆ ಕಾಂಪೊನೆಂಟ್ಗಳು ಯಾವಾಗ ಮತ್ತು ಹೇಗೆ ಮರು-ರೆಂಡರ್ ಆಗುತ್ತವೆ ಎಂಬುದರ ಮೇಲೆ ಇನ್ನೂ ಹೆಚ್ಚು ಸೂಕ್ಷ್ಮ-ನಿಯಂತ್ರಿತ ನಿಯಂತ್ರಣವನ್ನು ಹೊಂದಲು ಅನುವು ಮಾಡಿಕೊಡುತ್ತದೆ, ಕಾರ್ಯಕ್ಷಮತೆಯನ್ನು ಮತ್ತಷ್ಟು ಆಪ್ಟಿಮೈಜ್ ಮಾಡುತ್ತದೆ.
- ರಿಯಾಕ್ಟಿವ್ ಲೈಬ್ರರಿಗಳೊಂದಿಗೆ ಏಕೀಕರಣ: LWC RxJS ಅಥವಾ MobX ನಂತಹ ಜನಪ್ರಿಯ ರಿಯಾಕ್ಟಿವ್ ಲೈಬ್ರರಿಗಳೊಂದಿಗೆ ಹೆಚ್ಚು ಸುಗಮವಾಗಿ ಸಂಯೋಜನೆಗೊಳ್ಳಬಹುದು, ಡೆವಲಪರ್ಗಳಿಗೆ ಡೇಟಾ ಫ್ಲೋ ಮತ್ತು ಕಾಂಪೊನೆಂಟ್ ಅಪ್ಡೇಟ್ಗಳನ್ನು ನಿರ್ವಹಿಸಲು ವ್ಯಾಪಕ ಶ್ರೇಣಿಯ ಸಾಧನಗಳನ್ನು ಒದಗಿಸುತ್ತದೆ.
ತೀರ್ಮಾನ
@track
ಡೆಕೋರೇಟರ್ ಸೇಲ್ಸ್ಫೋರ್ಸ್ LWC ಯಲ್ಲಿ ವೆಬ್ ಕಾರ್ಯಕ್ಷಮತೆಯನ್ನು ಆಪ್ಟಿಮೈಜ್ ಮಾಡಲು ಒಂದು ಶಕ್ತಿಶಾಲಿ ಸಾಧನವಾಗಿದೆ. ಅದು ಹೇಗೆ ಕೆಲಸ ಮಾಡುತ್ತದೆ ಎಂಬುದನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳುವ ಮೂಲಕ ಮತ್ತು ಉತ್ತಮ ಅಭ್ಯಾಸಗಳನ್ನು ಅನುಸರಿಸುವ ಮೂಲಕ, ನೀವು ಉತ್ತಮ ಬಳಕೆದಾರ ಅನುಭವವನ್ನು ಒದಗಿಸುವ ಸ್ಪಂದನಾಶೀಲ ಮತ್ತು ದಕ್ಷ ಅಪ್ಲಿಕೇಶನ್ಗಳನ್ನು ನಿರ್ಮಿಸಬಹುದು. @track
ಅನ್ನು ಆಯಕಟ್ಟಿನ ರೀತಿಯಲ್ಲಿ ಬಳಸಲು, ಇಮ್ಮ್ಯೂಟಬಿಲಿಟಿಗೆ ಆದ್ಯತೆ ನೀಡಲು, ಮತ್ತು ಸಂಭಾವ್ಯ ಕಾರ್ಯಕ್ಷಮತೆಯ ಅಡಚಣೆಗಳನ್ನು ಗುರುತಿಸಲು ನಿಮ್ಮ ಕಾಂಪೊನೆಂಟ್ಗಳನ್ನು ಪ್ರೊಫೈಲ್ ಮಾಡಲು ಮರೆಯದಿರಿ. LWC ವಿಕಸನಗೊಳ್ಳುತ್ತಾ ಹೋದಂತೆ, ಇತ್ತೀಚಿನ ವೈಶಿಷ್ಟ್ಯಗಳು ಮತ್ತು ಉತ್ತಮ ಅಭ್ಯಾಸಗಳೊಂದಿಗೆ ಅಪ್-ಟು-ಡೇಟ್ ಆಗಿರುವುದು ಉನ್ನತ-ಕಾರ್ಯಕ್ಷಮತೆಯ ವೆಬ್ ಅಪ್ಲಿಕೇಶನ್ಗಳನ್ನು ನಿರ್ಮಿಸಲು ನಿರ್ಣಾಯಕವಾಗಿರುತ್ತದೆ.
@track
ನ ಶಕ್ತಿಯನ್ನು ಅಳವಡಿಸಿಕೊಳ್ಳಿ ಮತ್ತು LWC ಯ ಸಂಪೂರ್ಣ ಸಾಮರ್ಥ್ಯವನ್ನು ಅನ್ಲಾಕ್ ಮಾಡಿ!