Angular 2 shared service to pass data to component-to-component

后端 未结 3 403
南旧
南旧 2021-01-16 12:20

I am trying to pass the string value of this.title from my LandingPage.component to my ResultPage.component.

I retrieve the list.show value

相关标签:
3条回答
  • 2021-01-16 12:58

    In title.service.ts you can declare a variable called title and have setter and getter:

    title: string ="";
    
    // replace fetchTitle with setTitle 
    // remember to change it in the component too
    setTitle(title) {
        this.title = title;
      }
    
    getTitle() {
        return this.title;
      }
    

    Then, when ResultPage.component is initialized, call getTitle() from TitleService and set the result to a variable declared in the component.

    Here's an example of sharing data via shared services.

    0 讨论(0)
  • 2021-01-16 13:07

    Separation of concerns... Your landing page is used to select the list item and navigate to the result page. Let it do just that and only that. Let the ResultPage.component do the rest. Note: Other answers recommend storing the value of the last title in the TitleService. It's not a good idea to store state in a service. Then TitleService cannot be used as a generic way to get any title separate from your current navigation, without side effects.

    Remove (click) event. Add 'show' as a QueryParam.

    landingpage.component.html

    <li [routerLink]="['/details', list.id]" 
        [queryParams]="{show: list.show}" 
         *ngFor="let list of shows">
         {{list.show}}
    </li>
    

    Subscribe to router params and queryparams to get the id and show.

    resultpage.component.ts

    import { Component, OnInit, OnDestroy } from '@angular/core';
    import { ActivatedRoute, Router } from '@angular/router';
    import { TitleService } from '../../services/title.service';
    
    @Component({
      ...
    })
    export class ResultPageComponent implements OnInit, OnDestroy {
    
     itemId: string;
     show: string;
     subParams: any;       // infinite Observable to be unsubscribed
     subQueryParams: any;  // infinite Observable to be unsubscribed
    
     constructor(
              ... 
              private TitleService: TitleService,
              protected route: ActivatedRoute,
              protected router: Router,
              ...
     ) {}
    
     ngOnInit() {
       this.subParams = this.route.params.subscribe(this.onParams);
       this.subQueryParams = this.route.queryParams(this.onQueryParams);
     }
    
     ngOnDestroy() {
       // Delete active subscribes on destroy
       this.subParams.unsubscribe();  
       this.subQueryParams.unsubscribe();  
     }
    
     onParams = (params: any) => {
       this.itemId = params['id'];
     }
    
     onQueryParams = (data: any) => {
      this.show = data.show;
      if(this.show) {
        this.TitleService.fetchTitle(this.show)
      }
     }
    
    0 讨论(0)
  • 2021-01-16 13:11

    Make the title a public property of the service like this:

    // this gives us the name of the clicked show, which we send to TitleResolver
    @Injectable()
    export class TitleService {
      selectedTitle: string;
    
      fetchTitle(title) {
        console.log("title is " + title); // this outputs correctly
        this.selectedTitle = title;
        return title;   // No need to return it.
      }
    }
    

    Then any other component can inject this service and access this.titleService.selectedTitle

    0 讨论(0)
提交回复
热议问题