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

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

घटक निर्देश

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

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

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

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

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

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

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

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

ng g directive nameofthedirective
e.g
ng g directive changeText

यह कैसे कमांड लाइन में दिखाई देता है

C:\projectA6\Angular6App>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 (486 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 { 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
   ],
   providers: [],
   bootstrap: [AppComponent]
})
export class AppModule { }

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

परिवर्तन-पाठ। आदेश

import { Directive } from '@angular/core';
@Directive({
   selector: '[appChangeText]'
})
export class ChangeTextDirective {
   constructor() { }
}

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

में app.component.html देखें, हमें निर्देश इस प्रकार जोड़ें -

<div style = "text-align:center">
   <span appChangeText >Welcome to {{title}}.</span>
</div>

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

परिवर्तन-text.directive.ts

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

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

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

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