कोणीय 7 - घटक

कोणीय 7 के साथ विकास का प्रमुख हिस्सा घटकों में किया जाता है। घटक मूल रूप से कक्षाएं हैं जो घटक की .html फ़ाइल के साथ बातचीत करते हैं, जो ब्राउज़र पर प्रदर्शित होती है। हमने अपने पिछले अध्यायों में फ़ाइल संरचना को देखा है।

फ़ाइल संरचना में ऐप घटक है और इसमें निम्नलिखित फाइलें हैं -

  • app.component.css
  • app.component.html
  • app.component.spec.ts
  • app.component.ts
  • app.module.ts

और यदि आपने अपने प्रोजेक्ट सेटअप के दौरान कोणीय रूटिंग का चयन किया है, तो रूटिंग से संबंधित फाइलें भी जुड़ जाएंगी और फाइलें इस प्रकार हैं -

  • app-routing.module.ts

उपरोक्त फाइलें डिफ़ॉल्ट रूप से बनाई जाती हैं जब हमने कोणीय-क्ली कमांड का उपयोग करके नई परियोजना बनाई थी।

यदि आप खोलते हैं app.module.ts फ़ाइल, इसमें कुछ पुस्तकालय हैं जो आयात किए गए हैं और एक घोषणापत्र भी है जिसे इस प्रकार दिया गया है -

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module'; 
import { AppComponent } from './app.component';

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

घोषणाओं में AppComponent चर शामिल है, जिसे हमने पहले ही आयात कर लिया है। यह मूल घटक बन जाता है।

अब, कोणीय-क्लि में अपना स्वयं का घटक बनाने के लिए एक कमांड है। हालाँकि, डिफ़ॉल्ट रूप से बनाए गए एप्लिकेशन घटक हमेशा माता-पिता बने रहेंगे और बनाए गए अगले घटक बाल घटक बनाएंगे।

आइए अब हम कोड बनाने के लिए कमांड को नीचे की लाइन के साथ बनाते हैं -

ng g component new-cmp

जब आप कमांड लाइन में उपरोक्त कमांड चलाते हैं, तो आपको निम्न आउटपुट प्राप्त होंगे -

C:\projectA7\angular7-app>ng g component new-cmp 
CREATE src/app/new-cmp/new-cmp.component.html (26 bytes) 
CREATE src/app/new-cmp/new-cmp.component.spec.ts (629 bytes) 
CREATE src/app/new-cmp/new-cmp.component.ts (272 bytes) 
CREATE src/app/new-cmp/new-cmp.component.css (0 bytes) 
UPDATE src/app/app.module.ts (477 bytes)

अब, यदि हम जाते हैं और फ़ाइल संरचना की जांच करते हैं, तो हम नए-सीएमपी के तहत बनाए गए नए फ़ोल्डर को प्राप्त करेंगे src/app फ़ोल्डर।

निम्न फ़ाइलें नए-सीएमपी फ़ोल्डर में बनाई गई हैं -

  • new-cmp.component.css - नए घटक के लिए css फ़ाइल बनाई गई है।
  • new-cmp.component.html - html फ़ाइल बनाई गई है।
  • new-cmp.component.spec.ts - इसका उपयोग इकाई परीक्षण के लिए किया जा सकता है।
  • new-cmp.component.ts - यहां, हम मॉड्यूल, गुण आदि को परिभाषित कर सकते हैं।

में परिवर्तन किए जाते हैं app.module.ts फ़ाइल निम्नानुसार है -

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module'; 
import { AppComponent } from './app.component'; 
import { NewCmpComponent } from './new-cmp/new-cmp.component'; 

// includes the new-cmp component we created
@NgModule({ 
   declarations: [
      AppComponent, 
      NewCmpComponent 
      // here it is added in declarations and will behave as a child component 
   ], 
   imports: [ 
      BrowserModule,
      AppRoutingModule 
   ], 
   providers: [], 
      bootstrap: [AppComponent] 
      //for bootstrap the AppComponent the main app component is given. 
}) 
export class AppModule { }

new-cmp.component.ts फ़ाइल निम्नानुसार उत्पन्न होती है -

import { Component, OnInit } from '@angular/core'; // here angular/core is imported.

@Component({ 
   // this is a declarator which starts with @ sign. 
   // The component word marked in bold needs to be the same. 
   selector: 'app-new-cmp', // selector to be used inside .html file. 
   templateUrl: './new-cmp.component.html', 
   // reference to the html file created in the new component. 
   styleUrls: ['./new-cmp.component.css'] // reference to the style file. 
}) 
export class NewCmpComponent implements OnInit {   
   constructor() { } 
   ngOnInit() { } 
}

यदि आप उपरोक्त new-cmp.component.ts फ़ाइल देखते हैं, तो यह एक नया वर्ग बनाता है जिसे कहा जाता है NewCmpComponent, जो OnInit को लागू करता है जिसमें एक कंस्ट्रक्टर और एक विधि है जिसे ngOnInit () कहा जाता है। जब कक्षा निष्पादित की जाती है, तो ngOnInit को डिफ़ॉल्ट रूप से कहा जाता है।

आइए देखें कि प्रवाह कैसे काम करता है। अब, एप्लिकेशन घटक, जो डिफ़ॉल्ट रूप से बनाया गया है, मूल घटक बन जाता है। बाद में जोड़ा गया कोई भी घटक बाल घटक बन जाता है।

जब हम url को हिट करते हैं "http://localhost:4200/" ब्राउज़र, यह पहली बार index.html फ़ाइल को निष्पादित करता है जो नीचे दिखाया गया है -

<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Angular7App</title> 
      <base href = "/"> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1"> 
      <link rel = "icon" type = "image/x-icon" href = "favicon.ico"> 
   </head> 
   <body> 
      <app-root></app-root>
   </body> 

</html>

ऊपर सामान्य HTML फ़ाइल है और हमें ब्राउज़र में कुछ भी दिखाई नहीं देता है। हम शरीर अनुभाग में टैग पर एक नज़र डालेंगे।

<app-root></app-root>

यह डिफ़ॉल्ट रूप से कोणीय द्वारा बनाया गया रूट टैग है। इस टैग में संदर्भ हैmain.ts फ़ाइल।

import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module'; 
import { environment } from './environments/environment';

if (environment.production) { 
   enableProdMode(); 
}
platformBrowserDynamic().bootstrapModule(AppModule).catch(err => console.error(err));

AppModule को मुख्य पैरेंट मॉड्यूल के ऐप से आयात किया जाता है, और इसे बूटस्ट्रैप मॉड्यूल को दिया जाता है, जो Appmodule को लोड करता है।

अब हम देखते हैं app.module.ts फ़ाइल -

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module'; 
import { AppComponent } from './app.component'; 
import { NewCmpComponent } from './new-cmp/new-cmp.component';

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

यहां ही AppComponent नाम दिया गया है, अर्थात, के संदर्भ को संग्रहीत करने के लिए चर app.component.tsऔर वही बूटस्ट्रैप को दिया जाता है। अब हम देखते हैंapp.component.ts फ़ाइल।

import { Component } from '@angular/core';
@Component({
   selector: 'app-root', 
   templateUrl: './app.component.html', 
   styleUrls: ['./app.component.css'] 
}) 
export class AppComponent { 
   title = 'Angular 7'; 
}

कोणीय कोर को आयात किया जाता है और घटक के रूप में संदर्भित किया जाता है और इसका उपयोग निम्नानुसार किया जाता है -

@Component({ 
   selector: 'app-root', 
   templateUrl: './app.component.html', 
   styleUrls: ['./app.component.css'] 
})

चयनकर्ता के घोषणापत्र में टेम्प्लेट यूआरएल और स्टाइल यूआरएल दिए गए हैं। यहां चयनकर्ता और कुछ नहीं है, लेकिन जो टैग इंडेक्स। Html फ़ाइल में रखा गया है, जिसे हमने ऊपर देखा था।

AppComponent में एक वैरिएबल है जिसका शीर्षक है, जिसे ब्राउज़र में प्रदर्शित किया जाता है। @Component टेम्पलेट.com का उपयोग करता है, जिसे app.component.html कहा जाता है, जो इस प्रकार है -

<!--The content below is only a placeholder and can be replaced.--> 
<div style = "text-align:center"> 
   <h1> Welcome to {{ title }}! </h1> 
</div>

यह सिर्फ HTML कोड और घुंघराले कोष्ठक में चर शीर्षक है। इसे मूल्य के साथ बदल दिया जाता है, जो इसमें मौजूद हैapp.component.tsफ़ाइल। इसे बाइंडिंग कहा जाता है। हम बाद के अध्याय में बाध्यकारी की अवधारणा पर चर्चा करेंगे।

अब जब हमने एक नया घटक बनाया है जिसे नया-सीएमपी कहा जाता है। उसी में शामिल हो जाता हैapp.module.ts फ़ाइल, जब एक नया घटक बनाने के लिए कमांड चलाया जाता है।

app.module.ts बनाए गए नए घटक का संदर्भ है।

आइए अब नए-सीएमपी में बनाई गई नई फाइलों की जांच करें।

new-cmp.component.ts

import { Component, OnInit } from '@angular/core';
@Component({
   selector: 'app-new-cmp', 
   templateUrl: './new-cmp.component.html', 
   styleUrls: ['./new-cmp.component.css'] 
}) 
export class NewCmpComponent implements OnInit {   
   constructor() { } 
   ngOnInit() { } 
}

यहां, हमें कोर को भी आयात करना होगा। घटक का संदर्भ घोषणाकर्ता में उपयोग किया जाता है।

घोषणाकर्ता के पास ऐप-न्यू-सीएमपी और टेम्प्लेट यूआरएलएल और स्टाइल यूआरएल नामक चयनकर्ता है।

.Html को new-cmp.component.html कहा जाता है

<p> 
   new-cmp works!
</p>

जैसा कि ऊपर देखा गया है, हमारे पास html कोड यानी p टैग है। स्टाइल फ़ाइल खाली है क्योंकि हमें वर्तमान में किसी स्टाइलिंग की आवश्यकता नहीं है। लेकिन जब हम परियोजना चलाते हैं, तो हमें ब्राउज़र में प्रदर्शित होने वाले नए घटक से संबंधित कुछ भी दिखाई नहीं देता है।

ब्राउज़र निम्न स्क्रीन प्रदर्शित करता है -

हम प्रदर्शित किए जा रहे नए घटक से संबंधित कुछ भी नहीं देखते हैं। निर्मित नए घटक में निम्नलिखित विवरण के साथ एक .html फ़ाइल है -

<p>
   new-cmp works!
<p>

लेकिन हम ब्राउज़र में समान नहीं मिल रहे हैं। आइए अब हम नए घटकों को ब्राउज़र में प्रदर्शित करने के लिए आवश्यक परिवर्तन देखते हैं।

चयनकर्ता 'app-new-cmp'से नए घटक के लिए बनाया गया है new-cmp.component.ts जैसा कि नीचे दिखाया गया है -

import { Component, OnInit } from '@angular/core';

@Component({ 
   selector: 'app-new-cmp', 
   templateUrl: './new-cmp.component.html', 
   styleUrls: ['./new-cmp.component.css'] 
}) 
export class NewCmpComponent implements OnInit {  
   constructor() { } 
   ngOnInit() { } 
}

चयनकर्ता, अर्थात app-new-cmp app.component.html में जोड़ने की जरूरत है, अर्थात्, मुख्य माता पिता डिफ़ॉल्ट रूप से निम्नानुसार बनाया गया है -

<!--The content below is only a placeholder and can be replaced.-->
<div style = "text-align:center">
   <h1>
      Welcome to {{ title }}!
   </h1>
</div>
<app-new-cmp7></app-new-cmp>

जब <app-new-cmp></app-new-cmp> टैग जोड़ा गया है, जो सभी। html फ़ाइल में मौजूद है, अर्थात, बनाए गए नए घटक के new-cmp.component.html को मूल घटक डेटा के साथ ब्राउज़र पर प्रदर्शित किया जाएगा।

आइए हम बनाए गए नए घटक में कुछ और विवरण जोड़ते हैं और ब्राउज़र में प्रदर्शन देखते हैं।

new-cmp.component.ts

import { Component, OnInit } from '@angular/core';

@Component({
   selector: 'app-new-cmp',
   templateUrl: './new-cmp.component.html',
   styleUrls: ['./new-cmp.component.css']
})
export class NewCmpComponent implements OnInit {
   newcomponent = "Entered in new component created";
   constructor() { }
   ngOnInit() { }
}

कक्षा में, हमने एक चर कहा है newcomponent और मूल्य "निर्मित नए घटक में दर्ज किया गया" है।

उपरोक्त चर में जोड़ा गया है new-cmp.component.html फाइल इस प्रकार है -

<p> 
   {{newcomponent}} 
</p>
<p> 
   new-cmp works! 
</p>

अब चूंकि हमने शामिल कर लिया है <app-new-cmp></app-new-cmp>में चयनकर्ता app.component.html जो मूल घटक का .html है, उसमें मौजूद सामग्री new-cmp.component.htmlफ़ाइल ब्राउज़र पर प्रदर्शित हो जाती है। हम नए घटक के लिए नए cmp.component.css फ़ाइल में कुछ सीएसएस इस प्रकार जोड़ेंगे -

p { 
   color: blue; 
   font-size: 25px; 
}

इसलिए हमने p टैग्स के लिए नीले रंग और फ़ॉन्ट-आकार को 25px के रूप में जोड़ा है।

निम्न स्क्रीन ब्राउज़र में प्रदर्शित की जाएगी -

इसी तरह, हम घटकों का निर्माण कर सकते हैं और चयनकर्ता का उपयोग करके इसे लिंक कर सकते हैं app.component.html हमारी आवश्यकताओं के अनुसार फ़ाइल।