कोणीय 4 - इवेंट बाइंडिंग

इस अध्याय में, हम चर्चा करेंगे कि एंगुलर 4. में इवेंट बाइंडिंग कैसे काम करती है। जब कोई उपयोगकर्ता कीबोर्ड आंदोलन, माउस क्लिक, या माउसओवर के रूप में एक एप्लिकेशन के साथ इंटरैक्ट करता है, तो यह एक ईवेंट उत्पन्न करता है। इन घटनाओं को किसी प्रकार की कार्रवाई करने के लिए नियंत्रित करने की आवश्यकता है। यह वह जगह है जहाँ घटना बंधन चित्र में आता है।

आइए इसे बेहतर समझने के लिए एक उदाहरण पर विचार करें।

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>
      <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</ng-template>
   <ng-template #condition2>Condition is invalid</ng-template>
</div>
<button (click)="myClickFunction($event)">
   Click Me
</button>

में app.component.html फ़ाइल, हमने एक बटन परिभाषित किया है और क्लिक इवेंट का उपयोग करके इसमें एक फ़ंक्शन जोड़ा है।

बटन को परिभाषित करने और इसमें एक फ़ंक्शन जोड़ने के लिए सिंटैक्स निम्नलिखित है।

(click)="myClickFunction($event)"

फ़ंक्शन में परिभाषित किया गया है .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 4 Project!';
   //array of months.
   months = ["January", "Feburary", "March", "April",
            "May", "June", "July", "August", "September",
            "October", "November", "December"];
   isavailable = 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);
   }
}

बटन पर क्लिक करने पर, फ़ंक्शन पर नियंत्रण आ जाएगा myClickFunction और एक संवाद बॉक्स दिखाई देगा, जो प्रदर्शित करता है the Button is clicked जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है -

अब हम ड्रॉपडाउन में बदलाव की घटना को जोड़ते हैं।

कोड की निम्नलिखित पंक्ति आपको ड्रॉपडाउन में परिवर्तन की घटना को जोड़ने में मदद करेगी -

<!--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)">
      <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</ng-template>
   <ng-template #condition2>Condition is invalid</ng-template>
</div>

<button (click) = "myClickFunction($event)">Click Me</button>

समारोह में घोषित किया गया है 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", "Feburary", "March", "April",
            "May", "June", "July", "August", "September",
            "October", "November", "December"];
   isavailable = true;
   myClickFunction(event) {
      alert("Button is clicked");
      console.log(event);
   }
   changemonths(event) {
      console.log("Changed month from the Dropdown");
      console.log(event);
   }
}

कंसोल संदेश "Changed month from the Dropdownघटना के साथ कंसोल में प्रदर्शित किया गया है।

हमें एक अलर्ट संदेश जोड़ें 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 = 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");
   }
}

जब ड्रॉपडाउन में मान बदल जाता है, तो एक संवाद बॉक्स दिखाई देगा और निम्नलिखित संदेश प्रदर्शित होगा - "Changed month from the Dropdown"।