कोणीय 7 - निर्देश

कोणीय में निर्देश एक js वर्ग है, जिसे @directive के रूप में घोषित किया गया है। हमारे पास कोणीय में 3 निर्देश हैं। निर्देश नीचे सूचीबद्ध हैं -

घटक निर्देश

ये मुख्य वर्ग का विवरण देते हैं कि घटक को कैसे संसाधित किया जाना चाहिए, तत्काल और रनटाइम में उपयोग किया जाना चाहिए।

संरचनात्मक निर्देश

एक संरचना निर्देश मूल रूप से डोम तत्वों में हेरफेर करने से संबंधित है। निर्देश से पहले संरचनात्मक निर्देशों का एक * संकेत है। उदाहरण के लिए,*ngIf तथा *ngFor

निर्देश का गुण

विशेषता निर्देशक तत्व के रूप और व्यवहार को बदलने से संबंधित हैं। आप अपने स्वयं के निर्देश बना सकते हैं जैसा कि नीचे अनुभाग में बताया गया है।

कस्टम निर्देश कैसे बनाएँ?

इस खंड में, हम घटकों में उपयोग किए जाने वाले कस्टम निर्देशों के बारे में चर्चा करेंगे। कस्टम निर्देश हमारे द्वारा बनाए गए हैं और मानक नहीं हैं।

आइए देखें कि कस्टम निर्देश कैसे बनाएं। हम कमांड लाइन का उपयोग करके निर्देश बनाएंगे। कमांड लाइन का उपयोग करके निर्देश बनाने की कमान इस प्रकार है -

ng g directive nameofthedirective 
e.g 
ng g directive changeText

यह कमांड लाइन में दिखाई देता है जैसा कि नीचे दिए गए कोड में दिया गया है -

C:\projectA7\angular7-app>ng g directive changeText 
CREATE src/app/change-text.directive.spec.ts (241 bytes) 
CREATE src/app/change-text.directive.ts (149 bytes) 
UPDATE src/app/app.module.ts (565 bytes)

उपरोक्त फ़ाइलें, यानी, change-text.directive.spec.ts और change-text.directive.ts बनाई गई हैं और app.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'; 
import { NewCmpComponent } from'./new-cmp/new-cmp.component'; 
import { ChangeTextDirective } from './change-text.directive';

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

ChangeTextDirectiveउपरोक्त फ़ाइल में घोषणाओं में वर्ग शामिल है। नीचे दी गई फ़ाइल से भी वर्ग आयात किया जाता है -

change-text.directive

import { Directive } from '@angular/core';

@Directive({
   selector: '[changeText]'
})
export class ChangeTextDirective {
   constructor() { }
}

उपरोक्त फ़ाइल में एक निर्देश है और इसमें एक चयनकर्ता संपत्ति भी है। हम चयनकर्ता में जो भी परिभाषित करते हैं, उसे उसी दृश्य में मिलान करना होता है, जहां हम कस्टम निर्देश को निर्दिष्ट करते हैं।

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>
<div style = "text-align:center"> 
   <span changeText >Welcome to {{title}}.</span> 
</div>

हम परिवर्तनों को लिखेंगे change-text.directive.ts फाइल इस प्रकार है -

change-text.directive.ts

import { Directive, ElementRef} from '@angular/core';
@Directive({
   selector: '[changeText]'
})
export class ChangeTextDirective {
   constructor(Element: ElementRef) {
      console.log(Element);
      Element.nativeElement.innerText = "Text is changed by changeText Directive.";
   }
}

उपरोक्त फ़ाइल में, एक वर्ग कहा जाता है ChangeTextDirective और एक कंस्ट्रक्टर, जो टाइप का तत्व लेता है ElementRef, जो अनिवार्य है। तत्व में सभी विवरण हैं जिनके लिएChange Text निर्देश लागू किया जाता है।

हमने कंसोल.लॉग तत्व जोड़ दिया है। उसी के आउटपुट को ब्राउज़र कंसोल में देखा जा सकता है। जैसा कि ऊपर दिखाया गया है, तत्व का पाठ भी बदल गया है।

अब, ब्राउज़र निम्नलिखित दिखाएगा -

उस तत्व का विवरण जिस पर कंसोल में निर्देशक चयनकर्ता दिया गया है। जब से हमने जोड़ा हैchangeText स्पैन टैग के लिए निर्देश, स्पैन तत्व का विवरण प्रदर्शित किया जाता है।