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

Angular 4 का उपयोग करता है <ng-template> के बजाय टैग के रूप में <template>जिसका उपयोग Angular2 में किया जाता है। कारण कोणीय 4 बदल गया<template> सेवा <ng-template> क्योंकि वहाँ एक नाम संघर्ष के बीच है <template> टैग और HTML <template>मानक टैग। यह पूरी तरह से आगे बढ़ने में कमी करेगा। यह कोणीय 4 में बड़े बदलावों में से एक है।

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

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 4 Project!';
   //array of months.
   months = ["January", "February", "March", "April",
            "May", "June", "July", "August", "September",
            "October", "November", "December"];
   isavailable = false;
   myClickFunction(event) {
      this.isavailable = false;
   }
   changemonths(event) {
      alert("Changed month from the Dropdown");
      console.log(event);
   }
}

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

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

यदि आप ब्राउज़र का निरीक्षण करते हैं, तो आप देखेंगे कि डोम में स्पैन टैग नहीं है। यह हैCondition is invalid from template डोम में।

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>

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