कोणीय 6 - सेवाएं
इस अध्याय में, हम एंगुलर 6 में सेवाओं पर चर्चा करेंगे।
हम ऐसी स्थिति में आ सकते हैं, जहाँ हमें पृष्ठ पर हर जगह उपयोग किए जाने वाले कुछ कोड की आवश्यकता होती है। यह उन डेटा कनेक्शन के लिए हो सकता है जिन्हें घटकों के साथ साझा करने की आवश्यकता होती है, आदि सेवाएँ हमें वह हासिल करने में मदद करती हैं। सेवाओं के साथ, हम पूरे प्रोजेक्ट में अन्य घटकों के तरीकों और गुणों तक पहुंच सकते हैं।
एक सेवा बनाने के लिए, हमें कमांड लाइन का उपयोग करने की आवश्यकता है। उसी के लिए कमांड है -
C:\projectA6\Angular6App>ng g service myservice
CREATE src/app/myservice.service.spec.ts (392 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()
export class MyserviceService {
constructor() { }
}
यहाँ, इंजेक्टेबल मॉड्यूल से आयात किया जाता है @angular/core। इसमें शामिल है@Injectable विधि और एक वर्ग कहा जाता है MyserviceService। हम इस वर्ग में अपना सेवा कार्य करेंगे।
एक नई सेवा बनाने से पहले, हमें मुख्य माता-पिता में बनाई गई सेवा को शामिल करना होगा app.module.ts।
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule} from '@angular/router';
import { AppComponent } from './app.component';
import { MyserviceService } from './myservice.service';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
@NgModule({
declarations: [
SqrtPipe,
AppComponent,
NewCmpComponent,
ChangeTextDirective
],
imports: [
BrowserModule,
RouterModule.forRoot([
{
path: 'new-cmp',
component: NewCmpComponent
}
])
],
providers: [MyserviceService],
bootstrap: [AppComponent]
})
export class AppModule { }
हमने सेवा को वर्ग नाम के साथ आयात किया है और प्रदाताओं में उसी वर्ग का उपयोग किया जाता है। आइए अब हम सेवा वर्ग में वापस आते हैं और सेवा फ़ंक्शन बनाते हैं।
सेवा वर्ग में, हम एक फ़ंक्शन बनाएंगे जो आज की तारीख को प्रदर्शित करेगा। हम मुख्य मूल घटक में समान फ़ंक्शन का उपयोग कर सकते हैंapp.component.ts और नए घटक में भी new-cmp.component.ts कि हमने पिछले अध्याय में बनाया है।
आइए अब देखते हैं कि फ़ंक्शन सेवा में कैसा दिखता है और घटकों में इसका उपयोग कैसे किया जाता है।
import { Injectable } from '@angular/core';
@Injectable()
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 6 Project!';
todaydate;
constructor(private myservice: MyserviceService) {}
ngOnInit() {
this.todaydate = this.myservice.showTodayDate();
}
}
ngOnInitकिसी भी घटक में डिफ़ॉल्ट रूप से फ़ंक्शन को कॉल किया जाता है। दिनांक को सेवा से प्राप्त किया गया है जैसा कि ऊपर दिखाया गया है। सेवा के अधिक विवरण लाने के लिए, हमें पहले सेवा को घटक में शामिल करना होगाts फ़ाइल।
हम दिनांक प्रदर्शित करेंगे .html नीचे दिखाए अनुसार फ़ाइल -
{{todaydate}}
<app-new-cmp></app-new-cmp>
// data to be displayed to user from the new component class.
आइए अब देखते हैं कि बनाए गए नए घटक में सेवा का उपयोग कैसे करें।
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;
newcomponent = "Entered in new component created";
constructor(private myservice: MyserviceService) {}
ngOnInit() {
this.todaydate = this.myservice.showTodayDate();
}
}
हमारे द्वारा बनाए गए नए घटक में, हमें पहले उस सेवा को आयात करना होगा जो हम चाहते हैं और उसी के तरीकों और गुणों तक पहुंचें। कृपया हाइलाइट किए गए कोड को देखें। Todaydate को घटक HTML में निम्नानुसार प्रदर्शित किया जाता है -
<p>
{{newcomponent}}
</p>
<p>
Today's Date : {{todaydate}}
</p>
नए घटक के चयनकर्ता में प्रयोग किया जाता है app.component.htmlफ़ाइल। उपरोक्त HTML फ़ाइल की सामग्री को नीचे दिखाए गए ब्राउज़र में प्रदर्शित किया जाएगा -
यदि आप किसी घटक में सेवा की संपत्ति बदलते हैं, तो अन्य घटकों में भी इसे बदल दिया जाता है। आइए अब देखते हैं कि यह कैसे काम करता है।
हम सेवा में एक चर को परिभाषित करेंगे और इसका उपयोग अभिभावक और नए घटक में करेंगे। हम फिर से मूल घटक में संपत्ति को बदल देंगे और देखेंगे कि क्या नए घटक में वही बदल गया है या नहीं।
में myservice.service.ts, हमने एक संपत्ति बनाई है और अन्य माता-पिता और नए घटक में भी इसका उपयोग किया है।
import { Injectable } from '@angular/core';
@Injectable()
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 4 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;
}
}
अब हम वेरिएबल को लाएंगे और कंसोल.लॉग पर काम करेंगे। अगली पंक्ति में, हम चर के मान को बदलेंगे"component created"। हम उसी में करेंगे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 {
todaydate;
newcomponentproperty;
newcomponent = "Entered in newcomponent";
constructor(private myservice: MyserviceService) {}
ngOnInit() {
this.todaydate = this.myservice.showTodayDate();
this.newcomponentproperty = this.myservice.serviceproperty;
}
}
उपरोक्त घटक में, हम कुछ भी नहीं बदल रहे हैं लेकिन सीधे संपत्ति को घटक संपत्ति को सौंप रहे हैं।
अब जब आप इसे ब्राउज़र में निष्पादित करते हैं, तो सेवा संपत्ति को बदल दिया जाएगा क्योंकि इसके मूल्य को बदल दिया जाता है app.component.ts और उसी के लिए प्रदर्शित किया जाएगा new-cmp.component.ts।
परिवर्तित होने से पहले कंसोल में मान भी जांचें।