ಕೋನೀಯ 2 ಕಾಂಪೊನೆಂಟ್ ರಚನೆಯೊಂದಿಗೆ ಸಾಮಾನ್ಯ ಸಮಸ್ಯೆಗಳು: 'ಅಪ್ಲಿಕೇಶನ್-ಪ್ರಾಜೆಕ್ಟ್-ಲಿಸ್ಟ್' ದೋಷವನ್ನು ಗುರುತಿಸುವುದು ಮತ್ತು ಪರಿಹರಿಸುವುದು

Angular

ಕೋನೀಯ 2 ಕಾಂಪೊನೆಂಟ್ ಇಂಟಿಗ್ರೇಷನ್ ದೋಷನಿವಾರಣೆ

ಕೋನೀಯ 2 ಎಂಬುದು ಡೆವಲಪರ್‌ಗಳು ಡೈನಾಮಿಕ್ ವೆಬ್ ಅಪ್ಲಿಕೇಶನ್‌ಗಳನ್ನು ನಿರ್ಮಿಸಲು ಬಳಸುವ ಜನಪ್ರಿಯ ಫ್ರೇಮ್‌ವರ್ಕ್ ಆಗಿದೆ. ಕೋನೀಯ 2 ನೊಂದಿಗೆ ಪ್ರಾರಂಭಿಸುವಾಗ, ಆರಂಭಿಕರು ಎದುರಿಸುವ ಸವಾಲುಗಳಲ್ಲಿ ಒಂದು ಅಪ್ಲಿಕೇಶನ್‌ನಲ್ಲಿನ ಘಟಕಗಳ ರಚನೆ ಮತ್ತು ಸರಿಯಾದ ಏಕೀಕರಣವಾಗಿದೆ. ಹೊಸ ಘಟಕಗಳನ್ನು ಸರಿಯಾಗಿ ನೋಂದಾಯಿಸದಿದ್ದಾಗ ಸಾಮಾನ್ಯ ಸಮಸ್ಯೆ ಉದ್ಭವಿಸುತ್ತದೆ, ಸಂಕಲನ ಅಥವಾ ರನ್‌ಟೈಮ್ ಸಮಯದಲ್ಲಿ ವಿವಿಧ ದೋಷ ಸಂದೇಶಗಳಿಗೆ ಕಾರಣವಾಗುತ್ತದೆ.

ಈ ಸನ್ನಿವೇಶದಲ್ಲಿ, ದೋಷವು ನಿರ್ದಿಷ್ಟವಾಗಿ ಸಮಸ್ಯೆಯನ್ನು ಉಲ್ಲೇಖಿಸುತ್ತದೆ `

ಈ ರೀತಿಯ ದೋಷಗಳನ್ನು ಎದುರಿಸುವಾಗ, ನಿಮ್ಮ `app.module.ts` ಫೈಲ್‌ನಲ್ಲಿ ಕಾಂಪೊನೆಂಟ್‌ಗಳನ್ನು ಹೇಗೆ ಆಮದು ಮಾಡಿಕೊಳ್ಳಲಾಗುತ್ತದೆ ಮತ್ತು ಘೋಷಿಸಲಾಗುತ್ತದೆ ಎಂಬುದನ್ನು ಎರಡು ಬಾರಿ ಪರಿಶೀಲಿಸುವುದು ಮುಖ್ಯವಾಗಿದೆ. ಅಪ್ಲಿಕೇಶನ್‌ನಲ್ಲಿ ನಿರೀಕ್ಷಿಸಿದಂತೆ ಘಟಕಗಳು ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತವೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ಕೋನೀಯ ಮಾಡ್ಯೂಲ್‌ಗಳು ಮತ್ತು ಘಟಕ ಆಮದುಗಳನ್ನು ಸರಿಯಾಗಿ ನಿರ್ವಹಿಸುವುದು ಅತ್ಯಗತ್ಯ.

ಈ ಮಾರ್ಗದರ್ಶಿಯಲ್ಲಿ, ನಿಮ್ಮ `ಅಪ್ಲಿಕೇಶನ್-ಪ್ರಾಜೆಕ್ಟ್-ಲಿಸ್ಟ್` ಘಟಕದೊಂದಿಗೆ ನೀವು ಎದುರಿಸುತ್ತಿರುವ ದೋಷವನ್ನು ನಾವು ಒಡೆಯುತ್ತೇವೆ ಮತ್ತು ಅದನ್ನು ಸರಿಪಡಿಸಲು ಸ್ಪಷ್ಟ ಹಂತಗಳನ್ನು ಒದಗಿಸುತ್ತೇವೆ. ಈ ಪರಿಕಲ್ಪನೆಗಳನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳುವ ಮೂಲಕ, ಭವಿಷ್ಯದಲ್ಲಿ ಇದೇ ರೀತಿಯ ಸಮಸ್ಯೆಗಳನ್ನು ನಿವಾರಿಸಲು ಮತ್ತು ನಿಮ್ಮ ಕೋನೀಯ ಅಪ್ಲಿಕೇಶನ್‌ಗಳನ್ನು ಹೆಚ್ಚು ಪರಿಣಾಮಕಾರಿಯಾಗಿ ನಿರ್ಮಿಸಲು ನಿಮಗೆ ಸಾಧ್ಯವಾಗುತ್ತದೆ.

ಆಜ್ಞೆ ಬಳಕೆಯ ಉದಾಹರಣೆ
@NgModule ಕೋನೀಯದಲ್ಲಿ ಮುಖ್ಯ ಮಾಡ್ಯೂಲ್ ಮೆಟಾಡೇಟಾವನ್ನು ವ್ಯಾಖ್ಯಾನಿಸಲು ಈ ಡೆಕೋರೇಟರ್ ಅನ್ನು ಬಳಸಲಾಗುತ್ತದೆ. ಇದು ಘಟಕ ಘೋಷಣೆಗಳು, ಮಾಡ್ಯೂಲ್ ಆಮದುಗಳು, ಸೇವಾ ಪೂರೈಕೆದಾರರು ಮತ್ತು ಅಪ್ಲಿಕೇಶನ್ ಅನ್ನು ಪ್ರಾರಂಭಿಸಲು ಬೂಟ್‌ಸ್ಟ್ರ್ಯಾಪ್ ಸೆಟ್ಟಿಂಗ್‌ಗಳಂತಹ ಪ್ರಮುಖ ಕಾನ್ಫಿಗರೇಶನ್‌ಗಳನ್ನು ಒಳಗೊಂಡಿದೆ.
CUSTOM_ELEMENTS_SCHEMA ವೆಬ್ ಕಾಂಪೊನೆಂಟ್‌ಗಳು ಅಥವಾ ಕೋನೀಯ ಗುರುತಿಸದ ಕಸ್ಟಮ್ ಅಂಶಗಳ ಬಳಕೆಯನ್ನು ಅನುಮತಿಸಲು ಕೋನೀಯ NgModule ನಲ್ಲಿ ಬಳಸಲಾಗಿದೆ. ಈ ಸ್ಕೀಮಾವು ಟೆಂಪ್ಲೇಟ್‌ಗಳಲ್ಲಿ ಗುರುತಿಸದ ಅಂಶಗಳಿಗೆ ಸಂಬಂಧಿಸಿದ ದೋಷಗಳನ್ನು ತಡೆಯುತ್ತದೆ.
ComponentFixture ಕಾಂಪೊನೆಂಟ್‌ಗೆ ಫಿಕ್ಸ್ಚರ್ ರಚಿಸಲು ಕೋನೀಯ ಪರೀಕ್ಷೆಯಲ್ಲಿ ಇದನ್ನು ಬಳಸಲಾಗುತ್ತದೆ. ಇದು ಘಟಕ ನಿದರ್ಶನಕ್ಕೆ ಪ್ರವೇಶವನ್ನು ಒದಗಿಸುತ್ತದೆ ಮತ್ತು ಪರೀಕ್ಷಾ ಪರಿಸರದಲ್ಲಿ ಘಟಕದ ಕಾರ್ಯಚಟುವಟಿಕೆಗಳ ಪರಸ್ಪರ ಕ್ರಿಯೆ ಮತ್ತು ಪರೀಕ್ಷೆಯನ್ನು ಅನುಮತಿಸುತ್ತದೆ.
beforeEach ಅಗತ್ಯವಿರುವ ಯಾವುದೇ ಷರತ್ತುಗಳನ್ನು ಹೊಂದಿಸಲು ಕೋನೀಯ ಘಟಕ ಪರೀಕ್ಷೆಗಳಲ್ಲಿ ಪ್ರತಿ ಪರೀಕ್ಷಾ ಪ್ರಕರಣದ ಮೊದಲು ಈ ಕಾರ್ಯವನ್ನು ಕರೆಯಲಾಗುತ್ತದೆ. ಘಟಕ ರಚನೆ ಮತ್ತು ಮಾಡ್ಯೂಲ್ ಸೆಟಪ್ ಸೇರಿದಂತೆ ಪರೀಕ್ಷಾ ಪರಿಸರವನ್ನು ಪ್ರಾರಂಭಿಸಲು ಇದನ್ನು ಬಳಸಲಾಗುತ್ತದೆ.
TestBed ಘಟಕ ಪರೀಕ್ಷೆಗಳಲ್ಲಿ ಘಟಕಗಳನ್ನು ಹೊಂದಿಸಲು ಮತ್ತು ಕಾನ್ಫಿಗರ್ ಮಾಡಲು ಕೋನೀಯ ಪ್ರಾಥಮಿಕ ಪರೀಕ್ಷಾ ಉಪಯುಕ್ತತೆ. ಇದು ಪರೀಕ್ಷಾ ಮಾಡ್ಯೂಲ್ ಅನ್ನು ಕಾನ್ಫಿಗರ್ ಮಾಡುತ್ತದೆ ಮತ್ತು ಪ್ರತ್ಯೇಕ ಪರೀಕ್ಷಾ ಪರಿಸರದಲ್ಲಿ ಘಟಕಗಳನ್ನು ರಚಿಸುತ್ತದೆ.
subscribe ಕೋನೀಯದಲ್ಲಿ ಗಮನಿಸಬಹುದಾದ ವಸ್ತುಗಳಿಂದ ಅಸಮಕಾಲಿಕ ಡೇಟಾವನ್ನು ನಿರ್ವಹಿಸಲು ಬಳಸುವ ವಿಧಾನ. ಈ ಉದಾಹರಣೆಯಲ್ಲಿ, ಸೇವೆಯು API ನಿಂದ ಅದನ್ನು ಪಡೆದಾಗ ಪ್ರಾಜೆಕ್ಟ್ ಡೇಟಾವನ್ನು ಸ್ವೀಕರಿಸಲು ಇದು ProjectService ಗೆ ಚಂದಾದಾರರಾಗುತ್ತದೆ.
OnInit ಘಟಕವನ್ನು ಪ್ರಾರಂಭಿಸಿದ ನಂತರ ಕರೆಯಲಾಗುವ ಕೋನೀಯ ಜೀವನಚಕ್ರದ ಕೊಕ್ಕೆ. ಘಟಕವನ್ನು ರಚಿಸಿದಾಗ ಸೇವೆಗಳಿಂದ ಡೇಟಾವನ್ನು ಲೋಡ್ ಮಾಡುವಂತಹ ಕಾಂಪೊನೆಂಟ್ ಸೆಟಪ್ ಅನ್ನು ನಿರ್ವಹಿಸಲು ಇದನ್ನು ಸಾಮಾನ್ಯವಾಗಿ ಬಳಸಲಾಗುತ್ತದೆ.
detectChanges ಈ ವಿಧಾನವನ್ನು ಕೋನೀಯ ಘಟಕ ಪರೀಕ್ಷೆಗಳಲ್ಲಿ ಬದಲಾವಣೆ ಪತ್ತೆಹಚ್ಚುವಿಕೆಯನ್ನು ಪ್ರಚೋದಿಸಲು ಮತ್ತು ಪರೀಕ್ಷೆಯ ಸಮಯದಲ್ಲಿ ಘಟಕ ಡೇಟಾ ಅಥವಾ ಸ್ಥಿತಿಗಳನ್ನು ಮಾರ್ಪಡಿಸಿದ ನಂತರ ಘಟಕದ ವೀಕ್ಷಣೆಯನ್ನು ನವೀಕರಿಸಲಾಗಿದೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ಕರೆಯಲಾಗುತ್ತದೆ.

ಕೋನೀಯ 2 ಕಾಂಪೊನೆಂಟ್ ಸಮಸ್ಯೆಗಳಿಗೆ ಪರಿಹಾರವನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳುವುದು

ಒದಗಿಸಿದ ಸ್ಕ್ರಿಪ್ಟ್‌ಗಳಲ್ಲಿ, ಸರಿಯಾಗಿ ಕಾನ್ಫಿಗರ್ ಮಾಡುವುದು ಮತ್ತು ಘೋಷಿಸುವುದು ಮುಖ್ಯ ಉದ್ದೇಶವಾಗಿದೆ ಕೋನೀಯ 2 ಯೋಜನೆಯೊಳಗೆ. ನೀವು ಎದುರಿಸಿದ ದೋಷವು ಕಾಣೆಯಾದ ಘಟಕ ಘೋಷಣೆಗಳಿಗೆ ಅಥವಾ ಅಪ್ಲಿಕೇಶನ್ ಮಾಡ್ಯೂಲ್‌ನಲ್ಲಿ ತಪ್ಪಾದ ಕಾನ್ಫಿಗರೇಶನ್‌ಗೆ ಸಂಬಂಧಿಸಿದೆ. ಒದಗಿಸಿದ ಮೊದಲ ಪರಿಹಾರವು ಇದನ್ನು ಖಾತ್ರಿಪಡಿಸುವ ಮೂಲಕ ಪರಿಹರಿಸುತ್ತದೆ ಪ್ರಾಜೆಕ್ಟ್‌ಲಿಸ್ಟ್ ಕಾಂಪೊನೆಂಟ್ ಸರಿಯಾಗಿ ಆಮದು ಮಾಡಿಕೊಳ್ಳಲಾಗಿದೆ ಮತ್ತು `AppModule` ನಲ್ಲಿ ಘೋಷಿಸಲಾಗಿದೆ. ಇದು ಬಳಸುವುದನ್ನು ಒಳಗೊಂಡಿರುತ್ತದೆ ಡೆಕೋರೇಟರ್, ಇದು ಮಾಡ್ಯೂಲ್ ರಚನೆಯನ್ನು ವ್ಯಾಖ್ಯಾನಿಸುತ್ತದೆ. ಪ್ರಮುಖ ಆಜ್ಞೆಗಳಲ್ಲಿ ಘಟಕಗಳನ್ನು ನೋಂದಾಯಿಸಿದ `ಘೋಷಣೆಗಳು` ಮತ್ತು `ಬ್ರೌಸರ್ ಮಾಡ್ಯೂಲ್` ನಂತಹ ಇತರ ಅಗತ್ಯ ಮಾಡ್ಯೂಲ್‌ಗಳ ಏಕೀಕರಣವನ್ನು ನಿರ್ವಹಿಸುವ `ಆಮದುಗಳು` ಸೇರಿವೆ.

ಕೋನೀಯ ಅಪ್ಲಿಕೇಶನ್‌ಗಳೊಂದಿಗೆ ಆಗಾಗ್ಗೆ ಸಂಭವಿಸುವ ನಿರ್ದಿಷ್ಟ ಸಮಸ್ಯೆಗಳೆಂದರೆ ವೆಬ್ ಘಟಕಗಳನ್ನು ಬಳಸುವಾಗ ಕಸ್ಟಮ್ ಅಂಶ ಸ್ಕೀಮಾಗಳನ್ನು ಕಳೆದುಕೊಂಡಿರುವ ದೋಷವಾಗಿದೆ. ಇದನ್ನು ಪರಿಹರಿಸಲು, ಸ್ಕ್ರಿಪ್ಟ್ ಬಳಕೆಯನ್ನು ಪರಿಚಯಿಸುತ್ತದೆ , ಇದನ್ನು `@NgModule` ನಲ್ಲಿನ `ಸ್ಕೀಮಾಸ್` ಅರೇಗೆ ಸೇರಿಸಲಾಗಿದೆ. ಈ ಸ್ಕೀಮಾ ಕೋನೀಯಕ್ಕೆ ಕಸ್ಟಮ್ HTML ಟ್ಯಾಗ್‌ಗಳನ್ನು ಗುರುತಿಸಲು ಅನುಮತಿಸುತ್ತದೆ, ಇದು ಕೋನೀಯ ಪ್ರಮಾಣಿತ ಘಟಕ ರಚನೆಯ ಭಾಗವಾಗಿರುವುದಿಲ್ಲ. ಇದು ಇಲ್ಲದೆ, ಕೋನೀಯವು ಪರಿಚಯವಿಲ್ಲದ ಟ್ಯಾಗ್‌ಗಳನ್ನು ಎದುರಿಸಿದಾಗಲೆಲ್ಲಾ ದೋಷಗಳನ್ನು ಎಸೆಯುತ್ತದೆ, ಅವುಗಳು ತಪ್ಪಾಗಿ ಘೋಷಿಸಲಾದ ಘಟಕಗಳಾಗಿವೆ ಎಂದು ಊಹಿಸುತ್ತದೆ.

ಎರಡನೆಯ ಪರಿಹಾರವು ಘಟಕವು ಸರಿಯಾಗಿ ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತದೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳುವುದರೊಂದಿಗೆ ವ್ಯವಹರಿಸುತ್ತದೆ. ಇದು ಆಂಗ್ಯುಲರ್‌ನ ಅವಲಂಬನೆ ಇಂಜೆಕ್ಷನ್ ಸಿಸ್ಟಮ್ ಮೂಲಕ `ಪ್ರಾಜೆಕ್ಟ್‌ಲಿಸ್ಟ್ ಕಾಂಪೊನೆಂಟ್' ಗೆ ಚುಚ್ಚಲಾಗುತ್ತದೆ, ಡೇಟಾವನ್ನು ಪಡೆದುಕೊಳ್ಳಲು ಜವಾಬ್ದಾರಿಯುತವಾದ ಸೇವೆಯನ್ನು (`ಪ್ರಾಜೆಕ್ಟ್ ಸರ್ವಿಸ್`) ವ್ಯಾಖ್ಯಾನಿಸುತ್ತದೆ. `ngOnInit` ಲೈಫ್‌ಸೈಕಲ್ ಹುಕ್‌ನಲ್ಲಿ, ಪ್ರಾಜೆಕ್ಟ್ ಡೇಟಾವನ್ನು ಅಸಮಕಾಲಿಕವಾಗಿ ಹಿಂಪಡೆಯಲು `ಸಬ್‌ಸ್ಕ್ರೈಬ್' ವಿಧಾನವನ್ನು ಬಳಸಲಾಗುತ್ತದೆ. ಅಸಮಕಾಲಿಕ ಕಾರ್ಯಾಚರಣೆಗಳನ್ನು ನಿರ್ವಹಿಸಲು ಮತ್ತು API ಗಳಂತಹ ಬಾಹ್ಯ ಮೂಲಗಳಿಂದ ಡೇಟಾವನ್ನು ಸಂಯೋಜಿಸಲು ಕೋನೀಯದಲ್ಲಿ ಇದು ಸಾಮಾನ್ಯ ಮಾದರಿಯಾಗಿದೆ. `OnInit` ಇಂಟರ್ಫೇಸ್ ಅನ್ನು ಬಳಸುವುದರಿಂದ ಘಟಕವನ್ನು ಪ್ರಾರಂಭಿಸಿದ ತಕ್ಷಣ ಡೇಟಾ-ತರುವ ತರ್ಕವು ರನ್ ಆಗುತ್ತದೆ ಎಂದು ಖಚಿತಪಡಿಸುತ್ತದೆ.

ಅಂತಿಮ ಪರಿಹಾರವು ಪರೀಕ್ಷೆಯ ಮೇಲೆ ಕೇಂದ್ರೀಕರಿಸುತ್ತದೆ. ಘಟಕಗಳು ಮತ್ತು ಸೇವೆಗಳು ನಿರೀಕ್ಷಿಸಿದಂತೆ ಕಾರ್ಯನಿರ್ವಹಿಸುವುದನ್ನು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ಘಟಕ ಪರೀಕ್ಷೆಯು ಯಾವುದೇ ಕೋನೀಯ ಯೋಜನೆಯ ನಿರ್ಣಾಯಕ ಭಾಗವಾಗಿದೆ. ಒದಗಿಸಿದ ಪರೀಕ್ಷಾ ಸ್ಕ್ರಿಪ್ಟ್‌ನಲ್ಲಿ, ಪರೀಕ್ಷಾ ಪರಿಸರದಲ್ಲಿ ಘಟಕವನ್ನು ಹೊಂದಿಸಲು `TestBed` ಉಪಯುಕ್ತತೆಯನ್ನು ಬಳಸಲಾಗುತ್ತದೆ. `ಪ್ರತಿಯೊಂದಕ್ಕೂ ಮೊದಲು` ಕಾರ್ಯವು ಪ್ರತಿ ಪರೀಕ್ಷೆಯ ಮೊದಲು ಘಟಕವನ್ನು ಪ್ರಾರಂಭಿಸುತ್ತದೆ, ಆದರೆ `ಕಾಂಪೊನೆಂಟ್ ಫಿಕ್ಸ್ಚರ್` ಪರೀಕ್ಷೆಯ ಸಮಯದಲ್ಲಿ ಘಟಕದೊಂದಿಗೆ ನೇರ ಸಂವಾದವನ್ನು ಅನುಮತಿಸುತ್ತದೆ. ಈ ಪರೀಕ್ಷಾ ಚೌಕಟ್ಟು ನೈಜ ಪರಿಸರದಲ್ಲಿ ಘಟಕವು ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತದೆ ಎಂದು ಖಚಿತಪಡಿಸುತ್ತದೆ, ಆದರೆ ಪರೀಕ್ಷಾ ಪರಿಸರದಲ್ಲಿ ವಿವಿಧ ಪರಿಸ್ಥಿತಿಗಳಲ್ಲಿ ನಿರೀಕ್ಷಿಸಿದಂತೆ ವರ್ತಿಸುತ್ತದೆ. ಕೋನೀಯ ಅಭಿವೃದ್ಧಿಯಲ್ಲಿ ಉತ್ತಮ ಅಭ್ಯಾಸಗಳನ್ನು ಅನುಷ್ಠಾನಗೊಳಿಸುವಾಗ ಈ ಸ್ಕ್ರಿಪ್ಟ್‌ಗಳು ಒಟ್ಟಾಗಿ ಸಮಸ್ಯೆಯನ್ನು ಪರಿಹರಿಸುತ್ತವೆ.

ಕೋನೀಯ 2 ರಲ್ಲಿ 'ಅಪ್ಲಿಕೇಶನ್-ಪ್ರಾಜೆಕ್ಟ್-ಲಿಸ್ಟ್' ಕಾಂಪೊನೆಂಟ್ ಸಮಸ್ಯೆಯನ್ನು ಪರಿಹರಿಸಲಾಗುತ್ತಿದೆ

ವಿಧಾನ 1: ಮಾಡ್ಯೂಲ್ ಘೋಷಣೆಯನ್ನು ಸರಿಪಡಿಸುವುದು ಮತ್ತು ಪ್ರಾಜೆಕ್ಟ್‌ಲಿಸ್ಟ್ ಕಾಂಪೊನೆಂಟ್ ಅನ್ನು ಸರಿಯಾಗಿ ಆಮದು ಮಾಡಿಕೊಳ್ಳುವುದು

import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { ProjectListComponent } from './components/project-list/project-list.component';

@NgModule({
  declarations: [AppComponent, ProjectListComponent],
  imports: [BrowserModule],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

ಕೋನೀಯ 2 ರಲ್ಲಿ ಸರಿಯಾದ ಸೇವಾ ಇಂಜೆಕ್ಷನ್ ಮತ್ತು ಕಾಂಪೊನೆಂಟ್ ಇನಿಶಿಯಲೈಸೇಶನ್ ಅನ್ನು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳುವುದು

ವಿಧಾನ 2: ಕಾಂಪೊನೆಂಟ್‌ನ ಟೆಂಪ್ಲೇಟ್ ಅನ್ನು ಪರಿಶೀಲಿಸುವುದು, ಸೇವಾ ಇಂಜೆಕ್ಷನ್ ಮತ್ತು ಪ್ರಾಜೆಕ್ಟ್‌ಲಿಸ್ಟ್ ಕಾಂಪೊನೆಂಟ್‌ನ ಬಳಕೆ

import { Component, OnInit } from '@angular/core';
import { ProjectService } from '../../services/project.service';
import { Project } from '../../models/Project';

@Component({
  selector: 'app-project-list',
  templateUrl: './project-list.component.html',
  styleUrls: ['./project-list.component.scss']
})
export class ProjectListComponent implements OnInit {
  projects: Project[] = [];
  constructor(private projectService: ProjectService) { }

  ngOnInit(): void {
    this.projectService.getProjects().subscribe(data => {
      this.projects = data;
    });
  }
}

ಕೋನೀಯದಲ್ಲಿ ವೆಬ್ ಘಟಕಗಳಿಗಾಗಿ ಕಾಣೆಯಾದ ಸ್ಕೀಮಾ ದೋಷವನ್ನು ಪರಿಹರಿಸಲಾಗುತ್ತಿದೆ

ವಿಧಾನ 3: ವೆಬ್ ಘಟಕಗಳಿಗಾಗಿ ದೋಷಗಳನ್ನು ನಿಗ್ರಹಿಸಲು CUSTOM_ELEMENTS_SCHEMA ಅನ್ನು ಸೇರಿಸುವುದು

import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { ProjectListComponent } from './components/project-list/project-list.component';

@NgModule({
  declarations: [AppComponent, ProjectListComponent],
  imports: [BrowserModule],
  providers: [],
  bootstrap: [AppComponent],
  schemas: [CUSTOM_ELEMENTS_SCHEMA]
})
export class AppModule { }

ಕೋನೀಯದಲ್ಲಿ ProjectListComponent ಗಾಗಿ ಘಟಕ ಪರೀಕ್ಷೆಗಳನ್ನು ಸೇರಿಸಲಾಗುತ್ತಿದೆ

ವಿಧಾನ 4: ಘಟಕದ ಕಾರ್ಯವನ್ನು ಮೌಲ್ಯೀಕರಿಸಲು ಘಟಕ ಪರೀಕ್ಷೆಗಳನ್ನು ಅಳವಡಿಸುವುದು

import { TestBed } from '@angular/core/testing';
import { ProjectListComponent } from './project-list.component';
import { ProjectService } from '../../services/project.service';

describe('ProjectListComponent', () => {
  let component: ProjectListComponent;
  let fixture: ComponentFixture<ProjectListComponent>;

  beforeEach(async () => {
    await TestBed.configureTestingModule({
      declarations: [ ProjectListComponent ],
      providers: [ProjectService]
    }).compileComponents();
  });

  beforeEach(() => {
    fixture = TestBed.createComponent(ProjectListComponent);
    component = fixture.componentInstance;
    fixture.detectChanges();
  });

  it('should create the component', () => {
    expect(component).toBeTruthy();
  });
});

ಕೋನೀಯ 2 ರಲ್ಲಿ ಕಾಂಪೊನೆಂಟ್ ಸಂವಹನವನ್ನು ಎಕ್ಸ್‌ಪ್ಲೋರಿಂಗ್ ಮಾಡಲಾಗುತ್ತಿದೆ

ಕೋನೀಯ 2 ರಲ್ಲಿನ ಒಂದು ಪ್ರಮುಖ ಪರಿಕಲ್ಪನೆಯೆಂದರೆ ವಿಭಿನ್ನ ಘಟಕಗಳು ಪರಸ್ಪರ ಹೇಗೆ ಸಂವಹನ ನಡೆಸುತ್ತವೆ. ಸಂಕೀರ್ಣ ಅಪ್ಲಿಕೇಶನ್‌ನಲ್ಲಿ, ಡೇಟಾವನ್ನು ಹಂಚಿಕೊಳ್ಳಲು ಅಥವಾ ಬದಲಾವಣೆಗಳನ್ನು ಪರಸ್ಪರ ತಿಳಿಸಲು ನಿಮಗೆ ಆಗಾಗ್ಗೆ ಘಟಕಗಳು ಬೇಕಾಗುತ್ತವೆ. ಕೋನೀಯ 2 ಸೇರಿದಂತೆ ಈ ಸಂವಹನವನ್ನು ಸುಲಭಗೊಳಿಸಲು ಹಲವಾರು ಕಾರ್ಯವಿಧಾನಗಳನ್ನು ಒದಗಿಸುತ್ತದೆ ಮತ್ತು ಗುಣಲಕ್ಷಣಗಳು, ಸೇವೆಗಳು ಮತ್ತು EventEmitter. ಇವುಗಳನ್ನು ಬಳಸಿಕೊಂಡು, ಮಗುವಿನ ಘಟಕವು ತನ್ನ ಪೋಷಕರಿಗೆ ಡೇಟಾವನ್ನು ಮರಳಿ ಕಳುಹಿಸಬಹುದು ಅಥವಾ ಪೋಷಕರು ಅದರ ಮಗುವಿನ ಘಟಕಕ್ಕೆ ಡೇಟಾವನ್ನು ರವಾನಿಸಬಹುದು. ಬಹು ಘಟಕಗಳಾದ್ಯಂತ ಡೈನಾಮಿಕ್ ಡೇಟಾ ನವೀಕರಣಗಳೊಂದಿಗೆ ವ್ಯವಹರಿಸುವಾಗ ಇದನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳುವುದು ಬಹಳ ಮುಖ್ಯ.

ಕೋನೀಯ ನ ಘಟಕ ಕ್ರಮಾನುಗತದಲ್ಲಿ ನೇರವಾಗಿ ಸಂಬಂಧಿಸದ ಘಟಕಗಳ ನಡುವೆ ಸಂವಹನವನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುವಲ್ಲಿ ಪ್ರಮುಖ ಪಾತ್ರವನ್ನು ವಹಿಸುತ್ತದೆ. ಸೇವೆಯನ್ನು ರಚಿಸುವ ಮೂಲಕ ಮತ್ತು ಅಪೇಕ್ಷಿತ ಘಟಕಗಳಿಗೆ ಇಂಜೆಕ್ಟ್ ಮಾಡುವ ಮೂಲಕ, ನೀವು ಡೇಟಾ ಮತ್ತು ರಾಜ್ಯಗಳನ್ನು ಪರಿಣಾಮಕಾರಿಯಾಗಿ ಹಂಚಿಕೊಳ್ಳಬಹುದು. ಈ ಮಾದರಿಯನ್ನು ಹಂಚಿದ ಸೇವೆ ಎಂದು ಕರೆಯಲಾಗುತ್ತದೆ. ನಿಮ್ಮ ಕೋನೀಯ ಅಪ್ಲಿಕೇಶನ್‌ಗಳಲ್ಲಿ ಉತ್ತಮ ಸಂಘಟನೆ ಮತ್ತು ನಿರ್ವಹಣೆಯನ್ನು ಉತ್ತೇಜಿಸಲು, ಸಂವಹನ ಮಾಡಲು ಅವುಗಳನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುವಾಗ ನಿಮ್ಮ ಘಟಕಗಳು ಡಿಕೌಪಲ್ ಆಗಿರುವುದನ್ನು ಇದು ಖಚಿತಪಡಿಸುತ್ತದೆ.

ಮತ್ತೊಂದು ಪ್ರಮುಖ ವಿಷಯವೆಂದರೆ ಬಳಕೆ ಕೋನೀಯ 2 ರಲ್ಲಿ. RxJS ನ ಭಾಗವಾಗಿರುವ ಅವಲೋಕನಗಳು, HTTP ವಿನಂತಿಗಳು ಅಥವಾ ಬಳಕೆದಾರರ ಇನ್‌ಪುಟ್ ಈವೆಂಟ್‌ಗಳಂತಹ ಅಸಮಕಾಲಿಕ ಡೇಟಾ ಸ್ಟ್ರೀಮ್‌ಗಳನ್ನು ನಿರ್ವಹಿಸಲು ನಿಮಗೆ ಅನುಮತಿಸುತ್ತದೆ. API ಗಳಿಂದ ಡೇಟಾವನ್ನು ಪಡೆದುಕೊಳ್ಳಲು ಮತ್ತು ಡೇಟಾ ಬದಲಾದಾಗ ವೀಕ್ಷಣೆಯನ್ನು ನವೀಕರಿಸಲು ಕೋನೀಯ ಅಪ್ಲಿಕೇಶನ್‌ಗಳಲ್ಲಿ ಅವುಗಳನ್ನು ಹೆಚ್ಚು ಬಳಸಲಾಗುತ್ತದೆ. ಅವಲೋಕನಗಳನ್ನು ಸರಿಯಾಗಿ ನಿರ್ವಹಿಸುವುದು ಮತ್ತು `ಮ್ಯಾಪ್`, `ಫಿಲ್ಟರ್` ಮತ್ತು `ಸಬ್‌ಸ್ಕ್ರೈಬ್` ನಂತಹ ಆಪರೇಟರ್‌ಗಳನ್ನು ಹೇಗೆ ಬಳಸುವುದು ಎಂಬುದನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳುವುದು ನಿಮ್ಮ ಕೋನೀಯ ಘಟಕಗಳನ್ನು ಹೆಚ್ಚು ಪರಿಣಾಮಕಾರಿಯಾಗಿ ಮಾಡಲು ಮತ್ತು ಬಳಕೆದಾರರ ಕ್ರಿಯೆಗಳಿಗೆ ಸ್ಪಂದಿಸುವಂತೆ ಮಾಡಲು ಪ್ರಮುಖವಾಗಿದೆ.

  1. ಎರಡು ಕೋನೀಯ ಘಟಕಗಳ ನಡುವೆ ನಾನು ಹೇಗೆ ಸಂವಹನ ನಡೆಸಬಹುದು?
  2. ನೀವು ಬಳಸಬಹುದು ಮತ್ತು ಪೋಷಕರು ಮತ್ತು ಮಕ್ಕಳ ಘಟಕಗಳ ನಡುವೆ ಡೇಟಾವನ್ನು ರವಾನಿಸಲು ಡೆಕೋರೇಟರ್‌ಗಳು, ಅಥವಾ ಹಂಚಿಕೊಂಡಿದ್ದಾರೆ ಒಡಹುಟ್ಟಿದವರ ಘಟಕಗಳಿಗೆ.
  3. @NgModule ಡೆಕೋರೇಟರ್‌ನ ಉದ್ದೇಶವೇನು?
  4. ದಿ ಡೆಕೋರೇಟರ್ ಮಾಡ್ಯೂಲ್‌ನ ಮೆಟಾಡೇಟಾವನ್ನು ವ್ಯಾಖ್ಯಾನಿಸುತ್ತದೆ, ಇದರಲ್ಲಿ ಯಾವ ಘಟಕಗಳು ಮಾಡ್ಯೂಲ್‌ಗೆ ಸೇರಿವೆ, ಅದು ಆಮದು ಮಾಡಿಕೊಳ್ಳುವ ಮಾಡ್ಯೂಲ್‌ಗಳು ಮತ್ತು ಅದರ ಪೂರೈಕೆದಾರರು ಮತ್ತು ಬೂಟ್‌ಸ್ಟ್ರ್ಯಾಪ್ ಘಟಕಗಳು.
  5. ಕೋನೀಯದಲ್ಲಿ ಗಮನಿಸಬಹುದಾದ ವಸ್ತುಗಳ ಪಾತ್ರವೇನು?
  6. ಅಸಿಂಕ್ರೊನಸ್ ಡೇಟಾ ಸ್ಟ್ರೀಮ್‌ಗಳನ್ನು ನಿರ್ವಹಿಸಲು, ವಿಶೇಷವಾಗಿ HTTP ವಿನಂತಿಗಳು, ಈವೆಂಟ್ ಹ್ಯಾಂಡ್ಲಿಂಗ್ ಅಥವಾ ಡೇಟಾ ಬೈಂಡಿಂಗ್‌ಗಳಲ್ಲಿ ವೀಕ್ಷಿಸಬಹುದಾದವುಗಳನ್ನು ಬಳಸಲಾಗುತ್ತದೆ. ನೀವು ಬಳಸಿಕೊಂಡು ಡೇಟಾ ಹರಿವನ್ನು ನಿರ್ವಹಿಸಬಹುದು ಪ್ರತಿಕ್ರಿಯೆಗಳನ್ನು ನಿರ್ವಹಿಸಲು.
  7. "ಘಟಕವು ಮಾಡ್ಯೂಲ್ನ ಭಾಗವಾಗಿದೆ" ದೋಷವನ್ನು ನಾನು ಹೇಗೆ ಸರಿಪಡಿಸಬಹುದು?
  8. ನಲ್ಲಿ ಘಟಕವನ್ನು ಘೋಷಿಸಲಾಗಿದೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಿ ಮಾಡ್ಯೂಲ್‌ನ ರಚನೆ ಮತ್ತು ಅದು ಬೇರೆ ಮಾಡ್ಯೂಲ್‌ನಲ್ಲಿದ್ದರೆ ಸರಿಯಾಗಿ ಆಮದು ಮಾಡಿಕೊಳ್ಳಲಾಗುತ್ತದೆ.
  9. CUSTOM_ELEMENTS_SCHEMA ಯಾವುದಕ್ಕಾಗಿ ಬಳಸಲಾಗಿದೆ?
  10. ಗೆ ಈ ಸ್ಕೀಮಾವನ್ನು ಸೇರಿಸಲಾಗಿದೆ ಪ್ರಮಾಣಿತ ಕೋನೀಯ ಘಟಕಗಳಲ್ಲದ ಕಸ್ಟಮ್ ವೆಬ್ ಘಟಕಗಳ ಬಳಕೆಯನ್ನು ಅನುಮತಿಸಲು ಮಾಡ್ಯೂಲ್‌ನಲ್ಲಿ ಅರೇ.

ಕೋನೀಯ ಘಟಕ ದೋಷಗಳನ್ನು ಪರಿಹರಿಸುವಲ್ಲಿ, ಎಲ್ಲಾ ಘಟಕಗಳನ್ನು ಮಾಡ್ಯೂಲ್‌ನಲ್ಲಿ ಸರಿಯಾಗಿ ಘೋಷಿಸಲಾಗಿದೆ ಮತ್ತು ಆಮದು ಮಾಡಿಕೊಳ್ಳಲಾಗಿದೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳುವುದು ಬಹಳ ಮುಖ್ಯ. ಮಾಡ್ಯೂಲ್ ಆಮದುಗಳು ಅಥವಾ ಘೋಷಣೆಗಳಲ್ಲಿನ ತಪ್ಪು ಸಂರಚನೆಗಳು ಸಾಮಾನ್ಯವಾಗಿ ಈ ರೀತಿಯ ದೋಷಗಳಿಗೆ ಕಾರಣವಾಗುತ್ತವೆ. ಕೋನೀಯ ಮಾಡ್ಯೂಲ್‌ಗಳು ಹೇಗೆ ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತವೆ ಎಂಬುದನ್ನು ಅರ್ಥಮಾಡಿಕೊಳ್ಳುವುದು ಈ ಸಮಸ್ಯೆಗಳನ್ನು ತ್ವರಿತವಾಗಿ ಪರಿಹರಿಸಲು ಸಹಾಯ ಮಾಡುತ್ತದೆ.

ಇದಲ್ಲದೆ, ಕಸ್ಟಮ್ ವೆಬ್ ಘಟಕಗಳನ್ನು ನಿರ್ವಹಿಸಲು ನಿರ್ದಿಷ್ಟ ಸ್ಕೀಮಾಗಳ ಬಳಕೆಯ ಅಗತ್ಯವಿರುತ್ತದೆ . ಈ ಪರಿಕಲ್ಪನೆಗಳ ದೃಢವಾದ ತಿಳುವಳಿಕೆಯೊಂದಿಗೆ, ನಿಮ್ಮ ಕೋನೀಯ ಘಟಕಗಳು ಉತ್ತಮವಾಗಿ-ರಚನಾತ್ಮಕವಾಗಿವೆ, ಕ್ರಿಯಾತ್ಮಕವಾಗಿರುತ್ತವೆ ಮತ್ತು ವಿವಿಧ ಯೋಜನೆಗಳಲ್ಲಿ ನಿರ್ವಹಿಸಲು ಸುಲಭವಾಗಿದೆ ಎಂದು ನೀವು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಬಹುದು.

  1. ಮಾಡ್ಯೂಲ್-ಸಂಬಂಧಿತ ದೋಷಗಳನ್ನು ಪರಿಹರಿಸುವ ಸಲಹೆಗಳನ್ನು ಒಳಗೊಂಡಂತೆ ಕೋನೀಯ 2 ಘಟಕ ಆರ್ಕಿಟೆಕ್ಚರ್ ಮತ್ತು ದೋಷನಿವಾರಣೆಯನ್ನು ವಿವರಿಸುತ್ತದೆ. ಮೂಲ: ಕೋನೀಯ ಅಧಿಕೃತ ದಾಖಲೆ .
  2. ಪ್ರಾಜೆಕ್ಟ್‌ಸರ್ವಿಸ್‌ನ ಬಳಕೆಗೆ ಸಂಬಂಧಿಸಿದ ಕೋನೀಯ ಅಪ್ಲಿಕೇಶನ್‌ಗಳಲ್ಲಿ ಅವಲಂಬನೆ ಇಂಜೆಕ್ಷನ್ ಮತ್ತು ಸೇವಾ ಏಕೀಕರಣವನ್ನು ಚರ್ಚಿಸುತ್ತದೆ. ಮೂಲ: ಕೋನೀಯ ಅವಲಂಬನೆ ಇಂಜೆಕ್ಷನ್ ಗೈಡ್ .
  3. CUSTOM_ELEMENTS_SCHEMA ನಂತಹ ಸ್ಕೀಮಾಗಳನ್ನು ಬಳಸಿಕೊಂಡು ಕೋನೀಯದಲ್ಲಿ ಕಸ್ಟಮ್ ವೆಬ್ ಘಟಕಗಳನ್ನು ಹೇಗೆ ನಿರ್ವಹಿಸುವುದು ಎಂಬುದನ್ನು ವಿವರಿಸುತ್ತದೆ. ಮೂಲ: ಕೋನೀಯ CUSTOM_ELEMENTS_SCHEMA API .