कोणीय 7 - सेवाएं

हम ऐसी स्थिति में आ सकते हैं, जहाँ हमें पृष्ठ पर हर जगह उपयोग किए जाने वाले कुछ कोड की आवश्यकता होती है। उदाहरण के लिए, यह डेटा कनेक्शन के लिए हो सकता है जिसे घटकों के बीच साझा करने की आवश्यकता होती है। यह सेवाओं की मदद से हासिल किया गया है। सेवाओं के साथ, हम पूरे प्रोजेक्ट में अन्य घटकों के तरीकों और गुणों तक पहुंच सकते हैं।

सेवा बनाने के लिए, हमें नीचे दी गई कमांड लाइन का उपयोग करने की आवश्यकता है -

ng g service myservice
C:\projectA7\angular7-app>ng g service myservice 
CREATE src/app/myservice.service.spec.ts (348 bytes) 
CREATE src/app/myservice.service.ts (138 bytes)

एप्लिकेशन फ़ोल्डर में बनाई गई फाइलें इस प्रकार हैं -

निम्नलिखित फाइलें बनाई गई हैं जो नीचे दिखाई गई हैं - myservice.service.specs.ts और myservice.service.ts।

myservice.service.ts

import { Injectable } from '@angular/core';
@Injectable({
   providedIn: 'root' 
}) 
export class MyserviceService {
   constructor() { }
}

यहां, इंजेक्टेबल मॉड्यूल @ कोणीय / कोर से आयात किया जाता है। इसमें @Injectable पद्धति और एक वर्ग है, जिसे MyserviceService कहा जाता है। हम इस वर्ग में अपना सेवा कार्य करेंगे।

एक नई सेवा बनाने से पहले, हमें मुख्य माता-पिता में बनाई गई सेवा को शामिल करना होगा app.module.ts

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule , RoutingComponent} from './app-routing.module'; 
import { AppComponent } from './app.component'; 
import { NewCmpComponent } from './new-cmp/new-cmp.component'; 
import { ChangeTextDirective } from './change-text.directive'; 
import { SqrtPipe } from './app.sqrt'; 
import { MyserviceService } from './myservice.service';

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

हमने सेवा को वर्ग नाम के साथ आयात किया है, और प्रदाताओं में उसी वर्ग का उपयोग किया जाता है। आइए अब हम सेवा वर्ग में वापस आते हैं और सेवा फ़ंक्शन बनाते हैं।

सेवा वर्ग में, हम एक फ़ंक्शन बनाएंगे जो आज की तारीख को प्रदर्शित करेगा। हम मुख्य पैरेंट घटक app.component.ts में भी एक ही फ़ंक्शन का उपयोग कर सकते हैं और नए घटक new-cmp.component.ts में भी जो हमने पिछले अध्याय में बनाया था।

आइए अब देखते हैं कि फ़ंक्शन सेवा में कैसा दिखता है और घटकों में इसका उपयोग कैसे किया जाता है।

import { Injectable } from '@angular/core';
@Injectable({ 
   providedIn: 'root' 
}) 
export class MyserviceService { 
   constructor() { } 
   showTodayDate() { 
      let ndate = new Date(); 
      return ndate; 
   }  
}

उपरोक्त सेवा फ़ाइल में, हमने एक फ़ंक्शन बनाया है showTodayDate। अब हम बनाई गई नई तारीख () वापस करेंगे। आइए देखते हैं कि हम घटक वर्ग में इस फ़ंक्शन को कैसे एक्सेस कर सकते हैं।

app.component.ts

import { Component } from '@angular/core'; 
import { MyserviceService } from './myservice.service';
@Component({ selector: 'app-root', 
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css'] 
})
export class AppComponent { 
   title = 'Angular 7 Project!'; 
   todaydate;
   constructor(private myservice: MyserviceService) {}
   ngOnInit() { 
      this.todaydate = this.myservice.showTodayDate(); 
   } 
}

NgOnInit फ़ंक्शन को बनाए गए किसी भी घटक में डिफ़ॉल्ट रूप से कहा जाता है। दिनांक को सेवा से प्राप्त किया गया है जैसा कि ऊपर दिखाया गया है। सेवा के अधिक विवरण लाने के लिए, हमें पहले सेवा को घटक ts फ़ाइल में शामिल करना होगा।

हम नीचे दिखाए गए अनुसार .html फ़ाइल में दिनांक प्रदर्शित करेंगे -

app.component.html

{{todaydate}} 
<app-new-cmp></app-new-cmp>

आइए अब देखते हैं कि बनाए गए नए घटक में सेवा का उपयोग कैसे करें।

new-cmp.component.ts

import { Component, OnInit } from '@angular/core'; 
import { MyserviceService } from './../myservice.service';

@Component({ 
   selector: 'app-new-cmp', 
   templateUrl: './new-cmp.component.html', 
   styleUrls: ['./new-cmp.component.css'] 
}) 
export class NewCmpComponent implements OnInit { 
   newcomponent = "Entered in new component created"; 
   todaydate; 
   constructor(private myservice: MyserviceService) { }
   ngOnInit() { 
      this.todaydate = this.myservice.showTodayDate(); 
   } 
}

हमारे द्वारा बनाए गए नए घटक में, हमें पहले उस सेवा को आयात करना होगा जो हम चाहते हैं और उसी के तरीकों और गुणों तक पहुंचें। हाइलाइट किए गए कोड की जाँच करें। Todaydate को घटक html में निम्नानुसार प्रदर्शित किया जाता है -

new-cmp.component.html

<p> 
   {{newcomponent}} 
</p> 
<p> 
   Today's Date : {{todaydate}} 
</p>

नए घटक के चयनकर्ता का उपयोग app.component.html फ़ाइल में किया जाता है। उपरोक्त HTML फ़ाइल की सामग्री को नीचे दिखाए गए ब्राउज़र में प्रदर्शित किया जाएगा -

यदि आप किसी घटक में सेवा की संपत्ति बदलते हैं, तो अन्य घटकों में भी इसे बदल दिया जाता है। आइए अब देखते हैं कि यह कैसे काम करता है।

हम सेवा में एक चर को परिभाषित करेंगे और इसका उपयोग अभिभावक और नए घटक में करेंगे। हम फिर से मूल घटक में संपत्ति को बदल देंगे और देखेंगे कि क्या नए घटक में वही बदल गया है या नहीं।

में myservice.service.ts, हमने एक संपत्ति बनाई है और अन्य माता-पिता और नए घटक में भी इसका उपयोग किया है।

import { Injectable } from '@angular/core';
@Injectable({ 
   providedIn: 'root' 
}) 
export class MyserviceService { 
   serviceproperty = "Service Created"; 
   constructor() { } 
   showTodayDate() { 
      let ndate = new Date(); 
      return ndate; 
   } 
}

आइये अब हम उपयोग करते हैं servicepropertyअन्य घटकों में परिवर्तनशील। मेंapp.component.ts, हम चर को इस प्रकार देख रहे हैं -

import { Component } from '@angular/core'; 
import { MyserviceService } from './myservice.service';
@Component({
   selector: 'app-root', 
   templateUrl: './app.component.html', 
   styleUrls: ['./app.component.css'] 
})
export class AppComponent { 
   title = 'Angular 7 Project!'; 
   todaydate; 
   componentproperty; 
   constructor(private myservice: MyserviceService) {} 
   ngOnInit() { 
      this.todaydate = this.myservice.showTodayDate(); 
      console.log(this.myservice.serviceproperty); 
      this.myservice.serviceproperty = "component created"; 
      // value is changed. this.componentproperty = 
      this.myservice.serviceproperty; 
   } 
}

अब हम वेरिएबल को लाएंगे और कंसोल.लॉग पर काम करेंगे। अगली पंक्ति में, हम परिवर्तनशील के मान को "निर्मित घटक" में बदल देंगे। हम नए-cmp.component.ts में भी ऐसा ही करेंगे।

import { Component, OnInit } from '@angular/core'; 
import { MyserviceService } from './../myservice.service';
@Component({ 
   selector: 'app-new-cmp', 
   templateUrl: './new-cmp.component.html', 
   styleUrls: ['./new-cmp.component.css'] 
})
export class NewCmpComponent implements OnInit { 
   todaydate;
   newcomponentproperty; newcomponent = "Entered in 
   newcomponent"; constructor(private myservice: 
   MyserviceService) {} 
   ngOnInit() { 
      this.todaydate = this.myservice.showTodayDate(); 
      this.newcomponentproperty = 
      this.myservice.serviceproperty; 
   } 
}

उपरोक्त घटक में, हम कुछ भी नहीं बदल रहे हैं लेकिन सीधे संपत्ति को घटक संपत्ति को सौंप रहे हैं।

अब जब आप इसे ब्राउज़र में निष्पादित करते हैं, तो सेवा की संपत्ति बदल जाएगी क्योंकि इसके मूल्य को app.component.ts में बदल दिया जाता है और उसी को नए-cmp.component.ts के लिए प्रदर्शित किया जाएगा।

परिवर्तित होने से पहले कंसोल में मान भी जांचें।

यहाँ app.component.html और new-cmp.component.html फ़ाइलें हैं -

app.component.html

<h3>{{todaydate}}>/h3> 
<h3> Service Property : {{componentproperty}} </h3> 
<app-new-cmp></app-new-cmp>

new-cmp.component.html

<h3>{{newcomponent}} </h3> 
<h3> Service Property : {{newcomponentproperty}} </h3> 
<h3> Today's Date : {{todaydate}} </h3>