कोणीय 7 - टेम्पलेट

Angular 7 <ng> के बजाय टैग के रूप में <ng- टेम्पलेट> का उपयोग करता है, जो Angular2 में उपयोग किया जाता है। <एनजी-टेम्प्लेट> कोणीय 4 की रिलीज के बाद से उपयोग में लिया गया है, और पिछले संस्करण अर्थात कोणीय 2 <टेम्पलेट> एक ही उद्देश्य के लिए उपयोग करता है। इसका कारण कोणीय 4 के बाद से <टेम्पलेट> के बजाय <एनजी-टेम्पलेट> का उपयोग करना शुरू हुआ, क्योंकि <टेम्पलेट> टैग और HTML <टेम्पलेट> मानक टैग के बीच एक नाम संघर्ष है। यह पूरी तरह से आगे बढ़ने में कमी करेगा। यह कोणीय 4 संस्करण में किए गए प्रमुख परिवर्तनों में से एक था।

अब हम टेम्पलेट का उपयोग करते हैं if else condition और आउटपुट देखें।

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> Months :
   <select (change) = "changemonths($event)" name = "month">
      <option *ngFor = "let i of months">{{i}}</option>
   </select>
</div>
<br/>

<div>
   <span *ngIf = "isavailable;then condition1 else condition2">
      Condition is valid.
   </span>
   <ng-template #condition1>Condition is valid from template</ng-template>
   <ng-template #condition2>Condition is invalid from template</ng-template>
</div>
<button (click) = "myClickFunction($event)">Click Me</button>

स्पैन टैग के लिए, हमने जोड़ा है if के साथ बयान else कंडीशन और टेम्प्लेट कंडीशन 1 कहेगा, बाकी कंडीशन 2।

टेम्प्लेट्स को निम्नानुसार बुलाया जाना चाहिए -

<ng-template #condition1>Condition is valid from template</ng-template> 
<ng-template #condition2>Condition is invalid from template</ng-template>

अगर हालत सच है, तो condition1 टेम्पलेट कहा जाता है, अन्यथा condition2

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'; 
   
   // declared array of months. 
   months = ["January", "February", "March", "April", "May", "June", "July", 
      "August", "September", "October", "November", "December"]; 
   isavailable = false; // variable is set to true
   
   myClickFunction(event) { 
      //just added console.log which will display the event details in browser on click of the button. 
      alert("Button is clicked"); 
      console.log(event); 
   }
   changemonths(event) { 
      alert("Changed month from the Dropdown"); 
   } 
}

ब्राउज़र में आउटपुट निम्नानुसार है -

चर isavailableगलत है इसलिए condition2 टेम्पलेट प्रिंट किया गया है। यदि आप बटन पर क्लिक करते हैं, तो संबंधित टेम्पलेट कहा जाएगा।

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'; 
   
   // declared array of months. 
   months = ["January", "Feburary", "March", "April", "May", "June", "July", 
      "August", "September", "October", "November", "December"];
   
   isavailable = false; //variable is set to true  
   myClickFunction(event) { 
      this.isavailable = !this.isavailable; 
      // variable is toggled onclick of the button 
   } 
   changemonths(event) {
      alert("Changed month from the Dropdown"); 
   }
}

isavailable नीचे दिखाए गए अनुसार बटन पर क्लिक करने पर वेरिएबल टॉगल किया जाता है -

myClickFunction(event) { 
   this.isavailable = !this.isavailable; 
}

जब आप मूल्य के आधार पर बटन पर क्लिक करते हैं isavailable चर संबंधित टेम्पलेट प्रदर्शित किया जाएगा -

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

हालांकि में app.component.html हमने स्पैन टैग और जोड़ दिया है <ng-template> नीचे दी गई स्थिति के लिए -

<span *ngIf = "isavailable;then condition1 else condition2">
   Condition is valid.
</span> 
<ng-template #condition1>Condition is valid from template</ng-template>
<ng-template #condition2>Condition is invalid from template</ng-template>

जब हम ब्राउज़र में समान निरीक्षण करते हैं तो हम स्पैन टैग और डोम संरचना में <ng-टेम्पलेट> भी नहीं देखते हैं।

HTML में कोड की निम्नलिखित लाइन डोम में स्पैन टैग प्राप्त करने में हमारी मदद करेगी -

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

<div> Months : 
   <select (change) = "changemonths($event)" name = "month"> 
      <option *ngFor = "let i of months">{{i}}</option>
   </select> 
</div> 
<br/>

<div> 
   <span *ngIf = "isavailable; else condition2">
      Condition is valid.
   </span>
   <ng-template #condition1>Condition is valid from template </ng-template> 
   <ng-template #condition2>Condition is invalid from template</ng-template> 
</div>
<button (click) = "myClickFunction($event)">Click Me</button>

अगर हम निकालते हैं thenस्थिति, हमें ब्राउज़र में "शर्त मान्य है" संदेश मिलता है और डोम में स्पैन टैग भी उपलब्ध है। उदाहरण के लिए, मेंapp.component.ts, हमने बनाया है isavailable सत्य के रूप में परिवर्तनशील।